Response对象以及从服务端下载文件(解决乱码问题)

学java也有一段时间了,一直都没有写过博客,今天来写第一篇java学习经历的博客吧


今天学习的主要是response对象,在这里先放一个思维导图


Response对象作为响应,可以实现从服务端写数据到客户端,常见的如从服务端下载文件到客户端,代码如下:、

package download;

import java.io.BufferedInputStream;
import java.io.FileInputStream;
import java.io.IOException;
import java.net.URLEncoder;

import javax.servlet.ServletException;
import javax.servlet.ServletOutputStream;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import sun.misc.BASE64Encoder;

public class DownloadServlet2 extends HttpServlet {
	private static final long serialVersionUID = 736168762672095719L;

	public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {

		//**********中文编码解决***************
		/*
		 * 由于浏览器默认iso8859-1编码,不支持中文,从客户端获取filename会出现乱码
		 * filename参数需要进行转码,分别转为服务端可识别的文件名,用于确定服务端文件的绝对路径
		 * 还需要转为浏览器可识别的文件名,不同浏览器采用的编码不同,需要进行适配,才能在进行下载时显示正确的中文文件名
		 * 
		 * 关键是分别进行转码,生成能被服务端识别的中文文件名,和浏览器识别的中文文件名
		 */
		
		//获取请求体中的filename
		String filename = request.getParameter("filename");
		//转码为服务端能识别的中文文件名
		String filenameForServer = new String(filename.getBytes("iso8859-1"),"utf-8");
		//转码为客户端能识别的中文文件名,需要适配浏览器
		//获取浏览器的信息
		String agent = request.getHeader("user-agent");
		String filenameForBrowser = "";
		if (agent.contains("MSIE")) {
			// IE浏览器
			filenameForBrowser = URLEncoder.encode(filenameForServer, "utf-8");
			filenameForBrowser = filenameForBrowser.replace("+", " ");
		} else if (agent.contains("Firefox")) {
			// 火狐浏览器
			BASE64Encoder base64Encoder = new BASE64Encoder();
			filenameForBrowser = "=?utf-8?B?"
					+ base64Encoder.encode(filenameForServer.getBytes("utf-8")) + "?=";
		} else {
			// 其它浏览器
			filenameForBrowser = URLEncoder.encode(filenameForServer, "utf-8");				
		}
		
		//通过MIME协议,客户端确定文件的扩展名类型ServletContext.getMimeType(filename)
		response.setHeader("Content-Type", this.getServletContext().getMimeType(filenameForBrowser));
		//告知客户端该文件不直接解析,采用附件形式打开
		response.setHeader("Content-Disposition", "attachment;filename="+filenameForBrowser);
		//获取服务端文件的绝对路径
		String realPath = this.getServletContext().getRealPath("/download/"+filenameForServer);
		//获取输入输出流
		BufferedInputStream bis = new BufferedInputStream(new FileInputStream(realPath));
		ServletOutputStream out = response.getOutputStream();
		byte[] data = new byte[1024];
		int len = 0;
		while((len = bis.read(data)) != -1) {
			out.write(data, 0, len);
		}
	}

	public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
		doGet(request, response);
	}
}

html的代码如下

<!DOCTYPE html>
<html>
    <head>
        <meta charset="UTF-8">
        <title>下载</title>
    </head>
    <body>
        <h1>通过a标签进行文件下载</h1>
        <a href="/WEB14/download/a.jpg">a.jpg</a>
        <a href="/WEB14/download/a.flv">a.flv</a>
        <a href="/WEB14/download/a.mp3">a.mp3</a>
        <a href="/WEB14/download/a.mp4">a.mp4</a>
        <a href="/WEB14/download/a.txt">a.txt</a>
        <a href="/WEB14/download/a.zip">a.zip</a>
        <h1>通过Servlet进行文件下载</h1>
        <a href="/WEB14/download1?filename=a.jpg">a.jpg</a>
        <a href="/WEB14/download1?filename=a.flv">a.flv</a>
        <a href="/WEB14/download1?filename=a.mp3">a.mp3</a>
        <a href="/WEB14/download1?filename=a.mp4">a.mp4</a>
        <a href="/WEB14/download1?filename=a.txt">a.txt</a>
        <a href="/WEB14/download1?filename=a.zip">a.zip</a>
        <a href="/WEB14/download2?filename=美女.jpg">美女.jpg</a>
    </body>
</html>

实现效果如图


  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
使用response下载文件时,文件乱码问题通常是由于编码方式不一致造成的。为了解决这个问题,我们可以采取以下步骤: 1. 获取response的头部信息,并检查其中的Content-Disposition字段。该字段包含了文件名以及编码方式。 2. 使用Content-Disposition字段中的编码方式对文件名进行解码。常见的编码方式有UTF-8和ISO-8859-1。 3. 对解码后的文件名进行正确的编码方式编码。一般来说,UTF-8编码方式在中文环境中更常用。 4. 将编码后的文件名设置为下载文件的名称。 以下是一段示例代码,用于处理response下载文件时的文件乱码问题: ```python import requests import urllib.parse response = requests.get("下载文件的URL") # 获取Content-Disposition头部字段 content_disposition = response.headers["Content-Disposition"] # 获取编码方式 encoding = content_disposition[content_disposition.index("charset=") + len("charset="):] encoding = encoding.strip('"') # 解码文件名 file_name = content_disposition[content_disposition.index("filename=") + len("filename="):] file_name = urllib.parse.unquote(file_name, encoding=encoding) # 编码文件名 file_name = urllib.parse.quote(file_name, encoding="UTF-8") # 设置下载文件的名称 response.headers["Content-Disposition"] = 'attachment; filename="' + file_name + '"' # 下载文件 with open(file_name, "wb") as file: file.write(response.content) ``` 通过上述处理,我们可以在下载文件时正确地获取到文件名,并且避免了乱码问题

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值