原始的代码是这样的:
XML:
<constant name="struts.custom.i18n.resources" value="mess" />
<constant name="struts.i18n.encoding" value="GBK" />
<!-- 下载文件 -->
<action name="download" class="com.Action.DownloadAction">
<result type="stream" name="success">
<param name="contentType">application/octet-stream</param>
<!-- 要有相对应的getDownloadFile()方法返回值是 InputStream -->
<param name="inputName">downloadFile</param>
<param name="contentDisposition">attachment;filename="${fileName}"</param>
<param name="bufferSize">4096</param>
</result>
<result name="error" type="redirectAction">filelist</result>
</action>
注意此时的JSP编码为GBK才可以。如红字所示:
<%@ page language="java" contentType="text/html; charset=gbk"
pageEncoding="UTF-8"%>
XML中,fileName为从相应的Action中得到文件名的方法,即getFileName()。
Action中的原始代码:
public String getFileName() {
String name = "";
try {// 解决下载文件中文文件名问题
name = new String(fileName.getBytes("GBK"), "ISO8859-1");
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
System.out.println("getFileName....." + fileName);
return name;
}
这个代码可以解决绝大部分的问题。用IE可以正常下载,用谷歌火狐等浏览器貌似也可以正常下载中文文件名,但其实不是,个别汉字总是出现讨厌的乱码,如“说”字,如果它之前有空格,则会乱码。这是我在上传“susan 说.mp3”的时候发现的。。还有“之”字,也会乱码。不知道为什么大部分的汉字可以,这几个不行。
后来把GBK改为utf8,xml,JSP,Action中的全改,发现谷歌等非IE浏览器可以了!当时太开心了,用IE测试发现,乱码!!!无奈基础差找不到解决的办法,痛苦纠结了几个小时,一个一个编码测试。偶然发现当getter方法中编码为GBK时,IE没有问题,当编码为utf8时,谷歌没有问题,于是找到了解决了办法,就是在JAVA中测试是什么浏览器就可以了。
以下为最终代码,两个函数。
public String getFileName() {
String name = "";
try {// 解决下载文件中文文件名问题
if (isIE())
name = new String(fileName.getBytes("GBK"), "ISO8859-1");
else
name = new String(fileName.getBytes("utf8"), "ISO8859-1");
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
System.out.println("getFileName....." + fileName);
return name;
}
public static boolean isIE() {
return ServletActionContext.getRequest().getHeader("USER-AGENT")
.toLowerCase().indexOf("msie") > 0 ? true : false;
}
真是教训啊!
PS:如果大家都用一款浏览器多好啊。。。