博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
文件下载文件名乱码
阅读量:6219 次
发布时间:2019-06-21

本文共 690 字,大约阅读时间需要 2 分钟。

  hot3.png

背景

在做文件下载的过程中,发现原来的做法是直接给response.getOutputStream()中,写文件输入流的。并且在响应头中添加了content-disposition响应头来告诉浏览器下载文件名。但是这里冒出中文乱码问题。

旧的做法

response.setHeader("content-disposition","attachment;filename=" + URLEncoder.encode(fileName,"UTF-8"));

根据RFC 2616规定,HTTP 头必须是 ASCII 编码。这里使用UTF-8编码,浏览器只会使用ASCII 来解,然后就在前端乱码了。

新的做法

response.setHeader("content-disposition","attachment;filename*=UTF-8''" + URLEncoder.encode(fileName,"UTF-8"));

这里会主动告诉浏览器我使用的是UTF-8编码的文件名,这里主要使用了  标准来弄的。

content-disposition新协议

Content-Disposition: attachment;                     filename*=utf-8''%e2%82%ac%20rates

总结

抓住RFC协议,是我们Google解决问题的关键,尤其是要明白content-disposition的作用,只要弄懂这个一切都好办了。

参考:

转载于:https://my.oschina.net/fxtxz2/blog/1921920

你可能感兴趣的文章
开源SIP服务器加密软件NethidPro升级
查看>>
linux的简单命令
查看>>
我的友情链接
查看>>
大型网站技术架构(一)大型网站架构演化
查看>>
百度页面分享插件源代码
查看>>
易宝典文章——玩转Office 365中的Exchange Online服务 之六 了解Exchange Online对于邮箱使用的限制...
查看>>
确定jdk是32位版本还是64位版本
查看>>
linux下文件删除的原理
查看>>
python os.path模块
查看>>
评"抄袭就是生产力:评中国盛行的成功学逻辑"
查看>>
红客专用电脑安全工具箱 v 1.9
查看>>
$.noConflict()方法--常用的方式
查看>>
MongoDB的真正性能
查看>>
使用Zabbix监控windows服务
查看>>
win7 从硬盘重装操作系统(64位)
查看>>
CentOS-7安装Kubernetes-1.12.1
查看>>
如何进行感恩节的营销策划工作
查看>>
CCNP学习之路之GLBP
查看>>
H3C 6604通过OSPF向邻居发送本地静态路由
查看>>
报错java.lang.Long cannot be cast to java.lang.Integer解析
查看>>