我正在尝试从网络服务器下载文件并将其保存在服务器与文件一起发送的原始文件名下。下载效果很好,但我无法获得真实的文件名。
例如,我正在尝试下载此文件(Foxit PDF Reader)。
如果我在 Chrome 等浏览器中使用此链接,浏览器会下载包含版本等确切名称的文件。我从哪里获得此名称?我尝试阅读标题信息并正在搜索,Content-Disposition
但服务器没有发送此信息。我从哪里获得确切的文件名?
我试过这样的事情:
try {
URL webfile = new URL("http://www.foxitsoftware.com/downloads/latest.php?product=Foxit-Reader");
URLConnection con = webfile.openConnection();
Map map = con.getHeaderFields();
Set set = map.entrySet();
Iterator iterator = set.iterator();
while (iterator.hasNext()) {
System.out.println(iterator.next());
}
} catch (IOException ex) {
System.out.println("Error: "+ex.getMessage());
}
正如您在输出中看到的那样,没有Content-Disposition
:
null=[HTTP/1.1 200 OK]
ETag=["244005-f36d40-4d003f3868000"]
Date=[Sat, 08 Dec 2012 12:29:02 GMT]
Content-Length=[15953216]
Last-Modified=[Tue, 04 Dec 2012 10:01:36 GMT]
Content-Type=[application/x-msdos-program]
Connection=[close]
Accept-Ranges=[bytes]
Server=[Apache/2.2.16 (Debian)]
那么如何检索确切的文件名呢?浏览器中的链接下载名为 的文件FoxitReader544.11281_enu_Setup.exe
。
有任何想法吗?!