HttpServletResponse

1.HttpServletResponse概述

我们在创建Servlet时会覆盖service()方法,或doGet()/doPost(),这些方法都有两个参数,一个为代表请求的request和代表响应response。

service方法中的response的类型是ServletResponse,而doGet/doPost方法的response的类型是HttpServletResponse,HttpServletResponse是ServletResponse的子接口,功能和方法更加强大。HttpServletResponse专门用来封装HTTP响应消息,包括响应状态行,响应消息头,响应消息体三部分.

2 . response的运行流程

3.HttpServletResponse API中一些常用方法:

  3.1 负责向客户端(浏览器)发送响应状态码的相关方法(响应行)

  3.2 负责向客户端(浏览器)发送响应头的相关方法(响应头)

 设置字符编码

  3.3负责向客户端(浏览器)发送响应消息体的相关方法(响应体)

 响应头设置文本

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");就可以解决页面输出中文乱码问题。
响应头设置字节
ServletOutputStream getOutputStream()
获得字节流,通过该字节流的write(byte[] bytes)可以向response缓冲区中写入字节,在由Tomcat服务器将字节内容组成Http响应返回给浏览器。
注意:这两种方法不能同时使用,否则会发生illegalStateException异常。

4.文件下载原理

import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.net.URLEncoder;

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

/**
 * Servlet implementation class DownloadServlet
 */
@WebServlet("/Download")
public class DownloadServlet extends HttpServlet {
    private static final long serialVersionUID = 1L;
       
    /**
     * @see HttpServlet#HttpServlet()
     */
    public DownloadServlet() {
        super();
    }

    /**
     * @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse response)
     */
    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        //获取要下载文件的绝对路径
        String realPath= this.getServletContext().getRealPath("/美女.jpg");
        //获取文件名
        String fileName = realPath.substring(realPath.lastIndexOf("\")+1);
        System.out.println(fileName);
        //获取文件的MIME类型
        String type = this.getServletContext().getMimeType(fileName);
        System.out.println(type);
        //告知浏览器文件的类型
        //response.setHeader("content-type", type);
        response.setContentType(type);
        ///设置content-disposition响应头控制浏览器以下载的形式打开文件,中文文件名要使用
        //URLEncoder.encode(fileName,"UTF-8")方法进行编码,否则会出现文件名乱码
        response.setHeader("content-disposition","attachment;filename="+URLEncoder.encode(fileName,"UTF-8"));
        InputStream in = new FileInputStream(realPath);
        OutputStream os = response.getOutputStream();
        int len = 0;
        byte[] data = new byte[1024];
        while((len=in.read(data))!=-1){
            os.write(data, 0, len);
        }
        in.close();
        //os.close();//response获得的流不需要关闭,tomcat会自动将它关闭
        
    }

    /**
     * @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response)
     */
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        // TODO Auto-generated method stub
        doGet(request, response);
    }

}

 

 

 

原文地址:https://www.cnblogs.com/syp172654682/p/8400335.html