若是file.Name为中文则乱码。解决办法是
方法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)下载也是乱码。java