response.setHeader解决文件名只能输入17个汉字
来源:互联网 发布:互盾苹果数据恢复软件 编辑:程序博客网 时间:2024/05/22 00:27
原文件地址:http://hi.baidu.com/yuweiming/blog/item/a2ac4d08d1c0439e0b7b821b.html
如果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)下载也是乱码。
- response.setHeader解决文件名只能输入17个汉字
- response.setHeader(...)下载中文文件名乱码问题
- response.setHeader()下载中文文件名乱码问题
- response.setHeader()下载中文文件名乱码问题
- response.setHeader()下载中文文件名乱码问题
- response.setHeader()下载中文文件名乱码问题
- response.setHeader()下载中文文件名乱码问题
- response.setHeader()下载中文文件名乱码问题
- response.setHeader()下载中文文件名乱码问题
- 解决textbox 只能输入数字、汉字、字母
- response.setHeader
- response.setHeader
- response.setHeader()
- Response.setHeader
- response.setHeader
- response.setHeader()
- response.setHeader()
- 文件下载 response.setHeader()下载中文文件名乱码问题 解决办法
- MSSQLSERVER服务启动后又停止了
- 传智播客学习笔记05
- matlab排序
- 获取主板序列号
- Tabulate! 扩展:把你正在读的页面汇总成链接名单
- response.setHeader解决文件名只能输入17个汉字
- 理解 pkg-config 工具
- word2007自动提取数据制作成绩通知单
- java -- JVM笔记
- ubuntu10.10下,手动更新firefox
- WebKit介绍及总结(一)
- Android os设备谎言分辨率的解决方案
- Nginx出现“413 Request Entity Too Large”错误解决方法
- 阿拉伯数字转换成对应的大写中文输出