下载文件
1.直接使用a标签来去下载
有些内容会浏览器自动解析
浏览器不能解析的文件才会被下载
2.通过发送Servlet请求来去下载
通过发送一个Servlet请求,把文件名发送给服务器
发送给服务器后,接收到文件名参数,获取文件的绝对地址
通过流的形式来去写到浏览器
还得要告诉文件是什么类型
浏览器是以MIME的类型来识别类型
this.getServletContext().getMimeType(“文件名称”)
设置响应的类型
res.setContentType("MIME类型")
设置响应头,告诉浏览器不要去解析,是以附件的形式打开
res.setHeader("Content-Dsiposition","attachment;filename="+文件名)
解决中文名称乱码问题
获取中文参数报错问题
高版本tomcat中的新特性:就是严格按照 RFC 3986规范进行访问解析,而 RFC 3986规范定义了Url中只允许包含英文字母(a-zA-Z)、数字(0-9)、-_.~4个特殊字符以及所有保留字符(RFC3986中指定了以下字符为保留字符:! * ’ ( ) ; : @ & = + $ , / ? # [ ])
解决方案
.../conf/catalina.properties中,找到最后注释掉的一行 #tomcat.util.http.parser.HttpParser.requestTargetAllow=| ,改成tomcat.util.http.parser.HttpParser.requestTargetAllow=|{},表示把{}放行
1.把获取的字符串参数的字节码获取,再重新使用utf-8编码
2.在设置以附件形式打开时, 不同的浏览器会对默认的名字进行解码
所以根据不同的浏览器,要对名称进行编码之后,再放入文件名
对文件名进行编码
不同的浏览器编码不一样
要先获取agent,取出浏览器的类型
根据不同的浏览器类型进行编码
示例代码:
老九学堂会员社群出品
原文地址:https://www.cnblogs.com/ljxt/p/11608652.html