HttpServletResponse对象
Web服务器收到客户端的http请求,会针对每一次请求,分别创建一个用于代表请求的request对象和代表响应的response对象。
request和response对象代表请求和响应:获取客户端数据,需要通过request对象;向客户端输出数据,需要通过response对象。
HttpServletResponse的主要功能用于服务器对客户端的请求进行响应,将Web服务器处理后的结果返回给客户端。service()方法中形参接收的是HttpServletResponse接口的实例化对象,这个对象中封装了向客户端发送数据、发送响应头,发送响应状态码的方法。
响应数据
接收到客户端请求后,可以通过HttpServletResponse对象直接进行响应,响应时需要获取输出流。有两种形式:
- getWriter() 获取字符流(只能响应回字符)
- getOtputStream() 获取字节流(能响应一切数据)响应回的数据到客户端被浏览器解析。
注意:两者不能同时使用。同时使用会报错
java.lang.IllegalStateException: getWriter() has already been called for this response
// PrintWriter writer = resp.getWriter();
// writer.write("hello");
ServletOutputStream out = resp.getOutputStream();
out.write("hi".getBytes());
响应乱码问题
在响应中,如果我们响应的内容中含有中文,则有可能出现乱码。这是因为服务器响应的数据也会经过网络传输,服务器端有一种编码方式,在客户端也存在一种编码方式,当两端使用的编码方式不同时则出现乱码。
getWriter()的字符乱码
对于getWriter()获取到的字符流,响应中文必定出乱码,由于服务器端在进行编码时默认会使用ISO-8859-1格式的编码,该编码方式并不支持中文。
要解决该种乱码只能在服务器端告知服务器使用一种能够支持中文的编码格式,比如我们通常用的"UTF-8".
方式一:
//设置服务端的编码格式
resp.setCharacterEncoding("utf-8");
//设置客户端响应的MIME类型(识别html标签)和编码格式
resp.setHeader("content-type", "text/html;charset=UTF-8");
方式二:
//同时设置客户端和服务端的编码格式
resp.setContentType("text/html;charset=UTF-8");
getOutputStream()字节乱码
对于getOutputStream()方式获取到的字节流,响应中文时,由于本身就是传输的字节,所以此时可能出现乱码,也可能正确显示。当服务器端给的字材恰好和客户端使用的编码方式一致时则文本正确显示,否则出现乱码。无论如何我们都应该准确掌握服务器和客户端使用的是那种编码格式,以确保数据正确显示。
指定客户端和服务器使用的编码方式一致。
resp.setContentType("text/html;charset=UTF-8");
重定向
重定向是一种服务器指导,客户端的行为。客户端发出第一个请求,被服务器接收处理后,服务器会进行响应,在响应的同时,服务器会给客户端一个新的地址(下次请求的地址response.sendRedirect(url);),当客户端接收到响应后,会立刻、马上、自动根据服务器给的新地址发起第二个请求,服务器接收请求并作出响应,重定向完成。
从描述中可以看出重定向当中有两个请求存在,并且属于客户端行为。
//重定向跳转到index.jsp
resp.sendRedirect("index.jsp");
运行后地址栏发生变化,并且数据不会共享。
请求转发与重定向的区别
请求转发(req.getRequestDispatcher().forward()) | 重定向(resp.sendRedirect() |
---|---|
一次请求,数据在request域中共享 | 两次请求,request域中数据不共享 |
服务器端行为 | 客户端行为 |
地址栏不发生变化 | 地址栏发生变化 |
绝对地址定位到站点后(只能在站点内跳转) | 绝对地址可写到http:// |
网友评论