【转】解决response.AddHeader("Content-Disposition", "attachment; fileName=" + fileName) 中文显示乱码

如果fileName为中文则乱码。解决办法是

  • 方法1:

response.setHeader("Content-Disposition", "attachment; fileName=" + java.net.URLEncoder.encode(fileName, "UTF-8"));
下载的程序里有了上面一句,一般在IE6的下载提示框上将正确显示文件的名字,无论是简体中文,还是日文。但是文字只要超过17个字,就不能下载了。
一. 通过原来的方式,也就是先用URLEncoder编码,当中文文字超过17个时,IE6 无法下载文件。这是IE的bug,参见微软的知识库文章 KB816868 。原因可能是IE在处理 Response Header 的时候,对header的长度限制在150字节左右。而一个汉字编码成UTF-8是9个字节,那么17个字便是153个字节,所以会报错。而且不跟后缀也不对。

  • 方法2:

response.setHeader( "Content-Disposition", "attachment;filename=" + new String( fileName.getBytes("gb2312"), "ISO8859-1" ) ); 
在确保附件文件名都是简 体中文字的情况下,那么这个办法确实是最有效的,不用让客户逐个的升级IE。如果台湾同胞用,把gb2312改成big5就行。但现在的系统通常都加入了 国际化的支持,普遍使用UTF-8。如果文件名中又有简体中文字,又有繁体中文,还有日文。那么乱码便产生了。另外,在上Firefox (v1.0-en)下载也是乱码。

原文作者补充:纠正一个错误,一个汉字在UTF-8编码下是占用3个字节空间,不是9个!之所以在网络请求中会出9个字节是因为经过了URLEncode,一个字节被编码后会变成形如"%A5"的内容.所以一个汉字被UTF-8编码后占用3个字节空间,一个字节被URLEncode后变成3个字符,最终一个汉字就变成了9个字符。

笔者使用的是第一个方法,亲测有效,原文地址:http://www.cnblogs.com/zhycyq/p/3363365.html

posted @ 2017-04-13 09:42  我滴个小张张  阅读(828)  评论(0编辑  收藏  举报