HttpServletResponse概述

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

service方法中的response的类型是ServletResponse,而doGet/doPost方法的response的类型是HttpServletResponse,HttpServletResponse是ServletResponse的子接口,功能和方法更加强大,

2.response的运行流程https://www.chenqi.fun/wp-content/uploads/2018/06/response-1024x409.png

3.通过抓包工具抓取Http响应

https://www.chenqi.fun/wp-content/uploads/2018/06/xiangying.png

因为response代表响应,所以我们可以通过该对象分别设置Http响应的响应行,响 应头和响应体

4.通过response设置响应行

设置响应行的状态码

setStatus(int sc)

5.通过response设置响应头

addHeader(String name, String value)

addIntHeader(String name, int value)

addDateHeader(String name, long date)

setHeader(String name, String value)

setDateHeader(String name, long date)

setIntHeader(String name, int value)

其中,add表示添加,而set表示设置

6.通过response设置响应体

(1)响应体设置文本

PrintWriter getWriter()

如:

response.getWriter().write("你好!");

获得字符流,通过字符流的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");就可以解决页面输出中文乱码问题。

(2)响应头设置字节

ServletOutputStream getOutputStream()

获得字节流,通过该字节流的write(byte[] bytes)可以向response缓冲区中写入字 节,在由Tomcat服务器将字节内容组成Http响应返回给浏览器。

public class ByteServlet extends HttpServlet {

      protected void doGet(HttpServletRequest request, HttpServletResponse response)

                  throws ServletException, IOException {  

            //使用response获得字节输出流

            ServletOutputStream out = response.getOutputStream();
           //获得服务器上的图片

            String realPath = this.getServletContext().getRealPath("a.jpg");

            InputStream in = new FileInputStream(realPath);

            int len = 0;

            byte[] buffer = new byte[1024];

            while((len=in.read(buffer))>0){

                  out.write(buffer, 0, len);

            }          

            in.close();

            out.close();     

      }

      protected void doPost(HttpServletRequest request, HttpServletResponse response)

                  throws ServletException, IOException {

            doGet(request, response);

      }

}
                      文件的下载

public class DownLoadServlet2 extends HttpServlet {

      protected void doGet(HttpServletRequest request, HttpServletResponse response)

                  throws ServletException, IOException {

            //*******文件名称是中文的下载*******

            //获得要下载的文件的名称

            String filename = request.getParameter("filename");//????.jpg

            //解决获得中文参数的乱码----

            filename = new String(filename.getBytes("ISO8859-1"),"UTF-8");//美女.jpg       

            //获得请求头中的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");                 

            }

            //要下载的这个文件的类型-----客户端通过文件的MIME类型去区分类型

            response.setContentType(this.getServletContext().getMimeType(filename));

            //告诉客户端该文件不是直接解析 而是以附件形式打开(下载)----filename="+filename 客户端默认对名字进行解码

            response.setHeader("Content-Disposition", "attachment;filename="+filenameEncoder);




            //获取文件的绝对路径

            String path = this.getServletContext().getRealPath("download/"+filename);

            //获得该文件的输入流

            InputStream in = new FileInputStream(path);

            //获得输出流---通过response获得的输出流 用于向客户端写内容

            ServletOutputStream out = response.getOutputStream();

            //文件拷贝的模板代码

            int len = 0;

            byte[] buffer = new byte[1024];

            while((len=in.read(buffer))>0){

                  out.write(buffer, 0, len);

            }

            in.close();

            //out.close();

      }

      protected void doPost(HttpServletRequest request, HttpServletResponse response)

                  throws ServletException, IOException {

            doGet(request, response);

      }

}

HTML:

<h1>使用服务器端编码的方式实现文件下载</h1>

  <a href="/WEB14/downloadServlet?filename=a.flv">a.flv</a><br>

  <a href="/WEB14/downloadServlet?filename=a.jpg">a.jpg</a><br>

  <a href="/WEB14/downloadServlet?filename=a.mp3">a.mp3</a><br>

  <a href="/WEB14/downloadServlet?filename=a.mp4">a.mp4</a><br>

  <a href="/WEB14/downloadServlet?filename=a.txt">a.txt</a><br>

  <a href="/WEB14/downloadServlet?filename=a.zip">a.zip</a><br>

  <a href="/WEB14/downLoadServlet2?filename=美女.jpg">美女.jpg</a><br>

Response的细节点:

response获得的流不需要手动关闭,Tomcat容器会帮助我们关闭

getWriter和getOutputStream不能调用

重定向之后后面最好不要写代码

Last modification:July 29th, 2019 at 03:51 pm