layout: post
title: HttpServletResponse
subtitle: 用法
date: 2018-04-16
author: ZL
header-img: img/20180416.jpg
catalog: true
tags:
- Response
- web文件下载
HttpServletResponse
所有的doget和dopost方法都会有request和response参数。
response和request
浏览器的请求进过tomcat内部处理,被封装成一个request参数,放到了doget和dopost里面。
而response需要用户在doget或者dopost的代码里面为response添加内容,然后tomcat内部将这些内容封装好返回给浏览器。
原理性内容不看也罢
因为response代表响应,所以我们可以通过该对象分别设置Http响应的响应行,响 应头和响应体
response的一些API
设置响应行的状态码
setStatus(int sc)-
通过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表示设置这个头的条目除了它自带的比如Content-Length,自己也可以随便加比如addHeader(“name”, “zhangsan”),addHeader(“age”, “12”)等等
add表示添加,比如addHeader(“name”, “zhangsan”),addHeader(“name”, “lisi”),这样得到的response里面的name既有zhangsan也有lisi。而set表示修改,会把之前的内容覆盖而不是共存。 -
设置响应体
getWriter、getOutputStream()这两个方法不能同时调用,否则会报错
设置本地response编码
response.setCharacterEncoding("UTF-8");告诉浏览器使用何种编码解析
//通过一个头 Content-Type 告知客户端使用何种码表
response.setHeader("Content-Type", "text/html;charset=UTF-8");上面两句代码的结合(既设置response的编码格式,又可以告知浏览器解析格式,所以通常不用上面两句代码,而是用这一句)
response.setContentType("text/html;charset=UTF-8");-
重定向
-
方式一:
//告知客户端去重定向到servlet2 //1、设置状态码302 response.setStatus(302); //2、设置响应头Location response.setHeader("Location", "/WEB14/servlet2");
-
方式二:
//封装成一个重定向的方法sendRedirect(url) response.sendRedirect("/WEB14/servlet2");
-
定时刷新(延时重定向)
//设置定时刷新的头(5秒后跳转百度)
response.setHeader("refresh", "5;url=http://www.baidu.com");
下载文件的例子
-
下载名称没有中文的文件
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { //获得要下载的文件的名称 String filename = request.getParameter("filename");//a.flv //要下载的这个文件的类型-----客户端通过文件的MIME类型去区分类型 response.setContentType(this.getServletContext().getMimeType(filename)); //告诉客户端该文件不是直接解析 而是以附件形式打开(下载) response.setHeader("Content-Disposition", "attachment;filename="+filename); //获取文件的绝对路径 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 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(); }