用Struts2解决中文下载问题的时候。发现网上大多数人用的是如下的代码:
(1) struts.xml配置
<action name="fileDownload" class="demo.struts2.action.FileDownload" method="download">
<result name="success" type="stream">
"${contentType}"
inputStream
attachment;filename="${downloadFileName}"
4096
</result>
<interceptor-ref name="defaultStack"> </interceptor-ref>
</action>
(2) Action中的部分代码:
public String getDownloadFileName()
{
// 省略try/catch
String downFileName = this.fileName;
downFileName = new String(downFileName.getBytes(), "ISO8859-1");
return downFileName;
}
为这里对编码转化这里有些疑惑哦~~
downFileName = new String(downFileName.getBytes(), "ISO8859-1");
上面句活的含义不就是把 downFileName 按照本地编码(GBK)输出字节序列,
然后在将其按照 "ISO8859-1" 编码形式,进行“分割”操作。
问题就是在这里,如果是这样的话,客户端为什么会自动的把上面的内容(即:下载文件名自动识别出来的呢)
downFileName = new String(downFileName.getBytes(), "ISO8859-1");
这个是把你的字符重新编码成ISO8859-1
客户端为什么会识别呢?看下面的链接。
http://aguu125.blogbus.com/logs/29936890.html
[quote]
四、文件名为中文或其他unicode字符时的处理。
有时候提供下载的文件名中包含中文字符或者其他unicode字符,会导致浏览器无法正确的采用默认的文件名保存文件。我们应该记住在响应头中包含filename字段并采用ISO8859-1编码(推荐)或者采用UTF-8编码
[/quote]