编程语言
首页 > 编程语言> > 使用java下载文件时如何获取原始文件名

使用java下载文件时如何获取原始文件名

作者:互联网

当我用这样的URL从URL下载文件时,如何获取原始文件名

File file = new File( "test" ) ;
FileUtils.copyURLToFile(URL, file)

因为当我创建文件时我必须放一个名字,但在这个阶段我还不知道下载文件的原始名称.

解决方法:

对我来说,建议的文件名存储在头文件Content-Disposition中:

Content-Disposition: attachment; filename="suggestion.zip"

我正在从nexus下载文件,因此对于不同的服务器/应用程序,它可能存储在不同的头字段中,但很容易找到一些工具,如firebug for firefox.

以下几行对我来说很好

URL url = new URL(urlString);
// open the connection
URLConnection con = url.openConnection();
// get and verify the header field
String fieldValue = con.getHeaderField("Content-Disposition");
if (fieldValue == null || ! fieldValue.contains("filename=\"")) {
  // no file name there -> throw exception ...
}
// parse the file name from the header field
String filename = fieldValue.substring(fieldValue.indexOf("filename=\"") + 10, fieldValue.length() - 1);
// create file in systems temporary directory
File download = new File(System.getProperty("java.io.tmpdir"), filename);

// open the stream and download
ReadableByteChannel rbc = Channels.newChannel(con.getInputStream());
FileOutputStream fos = new FileOutputStream(download);
try {
  fos.getChannel().transferFrom(rbc, 0, Long.MAX_VALUE);
} finally {
  fos.close();
}

标签:java,tomcat,apache-commons
来源: https://codeday.me/bug/20190824/1707302.html