码迷,mamicode.com
首页 > 其他好文 > 详细

Servlet下载服务器上的文件Demo

时间:2019-09-29 16:50:46      阅读:93      评论:0      收藏:0      [点我收藏+]

标签:响应   获取   catalina   img   agent   中文参数   sip   注释   parser   

下载文件

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,取出浏览器的类型

根据不同的浏览器类型进行编码

示例代码:

 技术图片

 

 技术图片

 

 技术图片

老九学堂会员社群出品

Servlet下载服务器上的文件Demo

标签:响应   获取   catalina   img   agent   中文参数   sip   注释   parser   

原文地址:https://www.cnblogs.com/ljxt/p/11608652.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!