Java response响应体和文件下载实现原理
通过response 设置响应体:
响应体设置文本:
PrintWriter getWriter()
获得字符流,通过字符流的write(String s)方法可以将字符串设置到response 缓冲区中,随后Tomcat会将response缓冲区中的内容组装成Http响应返回给浏览 器端。
关于设置中文的乱码问题
原因:response缓冲区的默认编码是iso8859-1,此码表中没有中文,可以通过 response的setCharacterEncoding(String charset) 设置response的编码,
但我们发现客户端还是不能正常显示文字。
原因:我们将response缓冲区的编码设置成UTF-8,但浏览器的默认编码是本地系统的编码,因为我们都是中文系统,所以客户端浏览器的默认编码是GBK,我们可以手动修改浏览器的编码是UTF-8。
我们还可以在代码中指定浏览器解析页面的编码方式,通过response的setContentType(String type)方法指定页面解析时的编码是UTF-8。
response.setContentType('text/html;charset=UTF-8');
上面的代码不仅可以指定浏览器解析页面时的编码,同时也内含 setCharacterEncoding的功能,所以在实际开发中只要编写 response.setContentType('text/html;charset=UTF-8'),就可以解决页面输出中文乱码问题。
package com.oracle;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 DownloadServlet extends HttpServlet { protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { //服务器获取文件名(文件名是中文的话,获取的时候就成了乱码了) String filename = request.getParameter('file');//??.png //get请求中---解决文件名中文乱码问题 filename =new String(filename.getBytes('ISO-8859-1'),'UTF-8');//乱码.png//获取User-Agent获取客户端浏览器到底是哪个浏览器 String agent=request.getHeader('User-Agent'); String filenameEncoder=''; if (agent.contains('MSIE')) {// IE浏览器filenameEncoder= URLEncoder.encode(filename, 'utf-8');filenameEncoder= filenameEncoder.replace('+', ' '); } else if (agent.contains('Firefox')) {// 火狐浏览器 BASE64Encoder base64Encoder = new BASE64Encoder();filenameEncoder= '=?utf-8?B?' + base64Encoder.encode(filename.getBytes('utf-8')) + '?='; } else {// 其它浏览器filenameEncoder= URLEncoder.encode(filename, 'utf-8'); } //告知浏览器文件的类型(响应体) response.setContentType(getServletContext().getMimeType(filename)); //告知浏览器以附件的方式提供下载功能 而不是解析 response.setHeader('Content-Disposition','attachment;filename='+filenameEncoder); //服务器获取后开始进行复制的程序:获取字节输出流 ServletOutputStream sos = response.getOutputStream(); //获取数据源的绝对路径 String realpath = getServletContext().getRealPath('download/'+filename); //获取字节输入流 FileInputStream fis =new FileInputStream(realpath); //开始复制 byte[] bytes=new byte[1024]; int len=0; while((len=fis.read(bytes))!=-1){ sos.write(bytes, 0, len); } //释放资源 fis.close(); } protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { doGet(request, response); }}
<%@ page language='java' contentType='text/html; charset=UTF-8' pageEncoding='UTF-8'%><!DOCTYPE html PUBLIC '-//W3C//DTD HTML 4.01 Transitional//EN' 'http://www.w3.org/TR/html4/loose.dtd'><html><head><meta http-equiv='Content-Type' content='text/html; charset=UTF-8'><title>Insert title here</title></head><body> <a href='https://www.haobala.com/WEB02/DownLoadServlet?filename=a.txt' rel='external nofollow' >a.txt</a> <a href='https://www.haobala.com/WEB02/DownLoadServlet?filename=a.wmv' rel='external nofollow' >a.wmv</a> <a href='https://www.haobala.com/WEB02/DownLoadServlet?filename=科比.png' rel='external nofollow' >科比.png</a> <a href='https://www.haobala.com/WEB02/DownLoadServlet?filename=a.zip' rel='external nofollow' >a.zip</a></body></html>
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持好吧啦网。
相关文章:
