JSP下载中文乱码解决方法.docxVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
JSP下载中文乱码解决方法

JSP、Struts2下载中文文件名乱码问题 ?方案一: 原来处理下载的代码如下:? response.setHeader(Content-Disposition, attachment; filename= + .URLEncoder.encode(fileName, UTF-8)); 下载的程序里有了这句,一般在IE6的下载提示框上将正确显示文件的名字,无论是简体中文,还是日文。? 一. 上面方式,也就是先用URLEncoder编码,当中文文字超过17个时,IE6 无法下载文件。? 这是IE的bug,参见微软的知识库文章 KB816868 。? 原因可能是因为ie在处理 Response Header 的时候,对header的长度限制在150字节左右。? 而一个汉字编码成UTF-8是9个字节,那么17个字便是153个字节,所以便会报错。? 微软提供了一个补丁。这个补丁需要先安装ie6 sp1。? 二. 我尝试使用 javamail 的MimeUtility.encode()方法来编码文件名,也就是编码成 =?gb2312?B?xxxxxxxx?= 这样的形式, 并从 RFC1522 中找到对应的标准支持。不??很遗憾,IE6并不支持这一个标准。? 我试了一下,Firefox是支持的。? 三. 按网上很多人提供的解决方案:将文件名编码成ISO8859-1似乎是有效的解决方案,代码如下:? ???? response.setHeader( Content-Disposition, attachment;filename=+new String(fileName.getBytes(gb2312), ISO8859-1 ) ); 在确保附件文件名都是简体中文字的情况下,那么这个办法确实是最有效的,不用让客户逐个的升级IE。? 如果台湾同胞用,把gb2312改成big5就行。但现在的系统通常都加入了国际化的支持,普遍使用UTF-8。? 如果文件名中又有简体中文字,又有繁体中文,还有日文。那么乱码便产生了。? 另外,在我的电脑上Firefox (v1.0-en)下载也是乱码。? 折中考虑,我结合了一、三的方式,代码片断如下:? ??????? String fileName = URLEncoder.encode(atta.getFileName(), UTF-8);? ??????? /*? ???????? * see /default.aspx?kbid=816868? ???????? */? ??????? if (fileName.length() 150) {? ??????????? String guessCharset = xxxx /*根据request的locale 得出可能的编码,中文操作系统通常是gb2312*/ ??????????? fileName = new String(atta.getFileName().getBytes(guessCharset), ISO8859-1); ??????? }? ??????? response.setHeader(Content-Disposition, attachment; filename= + fileName); ???????? 暂且不考虑 Firefox。? /////////////////////? 下面是解决文件名空格问题? String fileName = StringUtils.trim(file.getName());? String formatFileName = encodingFileName(name);//在后面定义方法encodingFileName(String fileName); response.setHeader(Content-Disposition, attachment; filename= + formatFileName ); //处理文件名中出现的空格??? //其中%20是空格在UTF-8下的编码? public static String encodingFileName(String fileName) {? ??????? String returnFileName = ;? ??????? try {? ??????????? returnFileName = URLEncoder.encode(fileName, UTF-8);? ??????????? returnFileName = StringUtils.replace(returnFileName, +, %20);? ??????????? if (returnFileName.length()

文档评论(0)

yan698698 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档