我正在使用此Java代码从Internet下载文件:
String address = "http://melody.syr.edu/pzhang/publications/AMCIS99_vonDran_Zhang.pdf";
URL url = new URL(address);
System.out.println("Opening connection to " + address + "...");
URLConnection urlC = url.openConnection();
urlC.setRequestProperty("User-Agent", "");
urlC.connect();
InputStream is = urlC.getInputStream();
FileOutputStream fos = null;
fos = new FileOutputStream("myFileName");
int oneChar, count = 0;
while ((oneChar = is.read()) != -1) {
System.out.print((char)oneChar);
fos.write(oneChar);
count++;
}
is.close();
fos.close();
System.out.println(count + " byte(s) copied");
我想知道是否有办法让我只下载文件的一部分。 例如,对于一个5MB的文件来下载最后的2MB。
答案 0 :(得分:4)
如果服务器支持它(并且HTTP 1.1服务器应该),您可以使用范围请求:
http://www.w3.org/Protocols/rfc2616/rfc2616-sec14.html#sec14.35
此外,一次读取一个字符的效率非常低 - 你应该用4,16或32 KB的块读取。
答案 1 :(得分:2)