Servlet中HttpServletResponse的应用
一 回顾HttpServletRequest对象
1.服务端和客户端
(1)服务器端servlet程序中的servic产生应答信息HttpServletReasponse对象
(2)客户端浏览器向web服务器发送请求httpServletRequset对象
2.Request对象的回顾
(1)请求行GET/demo/test?usename=xxx HTTP/1.1
(2)请求消息头:getHeader(”头字段的名称”)
(3)获取所需要的参数 getParameter(”参数名”) 参数
(4)消息实体的内容
通过输入输出流获取 :getInputStream() 和 getReader()
在读取的时候通过流对象.read()方法读取
二 介绍HttpServletResponse对象
1.状态行 http/1.1 200 OK
可设置状态码,但是一般不需要
2.响应消息的消息头
(1)页面的设置文本类型
response.setContentType(“text/html“);
(2)页面的刷新
response.setHeader(“Refresh”,”2;url=”http://www.baidu.com”);
(3)设置浏览器不缓存的三种方法,是为了避免不同版本的浏览器。
response.setDateHeader("Expires", 0);
response.setHeader("Cache-Control", "no-cache");
response.setHeader("pragma", "no-cache");
使用<meta>标签设置响应消息头 ---在静态页面中设置
<meta http-equiv="content-type" content="text/html; charset=UTF-8">
3.消息实体内容
通过输出流对象进行设置,用以下两个方法:
Response.getOutputStream() 字节输出流对象
Response.getWriter() 字符的输出流对象
4.getOutputStream和getWriter方法的比较
(1)getOutputStream方法用于返回Servlet引擎创建的字节输出流对象,Servlet程序可以按字节形式输出响应正文。
(2)getWriter方法用于返回Servlet引擎创建的字符输出流对象,Servlet程序可以按字符形式输出响应正文。
(3)getOutputStream和getWriter这两个方法互相排斥,调用了其中的任何一个方法后,就不能再调用另一方法。
要不会出现错误java.lang.IllegalStateException
(4)getOutputStream方法返回的是字节输出流对象的类型
为ServletOutputStream,它可以直接输出字节数组中的二进制数据。
(5)getWriter方法将Servlet引擎的数据缓冲区包装成PrintWriter类型的字符输出流对象后返回,PrintWriter对象可以直接输出字符文本内容。
(6)Servlet程序向ServletOutputStream或PrintWriter对象中写入的数据将被Servlet引擎获取,Servlet引擎将这些数据当作响应消息的正文,然后再与响应状态行和各响应头组合后输出到客户端。
(7)Serlvet的service方法结束后,Servlet引擎将检查getWriter或getOutputStream方法返回的输出流对象是否已经调用过close方法,如果没有,Servlet引擎将调用close方法关闭该输出流对象。
注:out.close();系统会自己释放,但一般写上
5. 选择getOutputStream和getWrite方法的要点
(1)PrintWriter对象输出字符文本内容时,它内部还是将字符串转换成了某种字符集编码的字节数组后再进行输出,使用PrintWriter对象的好处就是不用编程人员自己来完成字符串到字节数组的转换。
(2)使用ServletOutputStream对象也能输出内容全为文本字符的网页文档,但是,如果网页文档内容是在Servlet程序内部使用文本字符串动态拼凑和创建出来的,则需要先将字符文本转换成字节数组后输出。
(3)如果一个网页文档内容全部为字符文本,但是这些内容可以直接从一个字节输入流中读取出来,然后再原封不动地输出到客户端,那么就应该使用ServletOutputStream对象直接进行输出,而不要使用PrintWriter对象进行输出。
三 出现乱码的原因和解决
1. java程序中默认的是中文字符----unicode
2.字符输出流对象----out.println()的字符编码的转变
系统会把在java程序中的unicode字符按照某种字符集编码的方式转换成字节数组,再通过浏览器输出,浏览器在输出的时候要进行解码,只有在这两种方式一样的情况下,才不会出现乱码。
注:(1)某种字符编码是用reponse对象去设置的,而且必须是在out.println之前使用,要不会出现错误,会抛找不到设置的字符编码而出错。
设置编码的两种方式:
response.setContentType("text/html;charset=utf-8");
request.setCharacterEncoding("utf-8");
(2)浏览器会把字节数组转换成字符
3. 系统默认的编码方式为ISO8859-1,如果没有指定字符编码,则输出的都是乱码,而且ISO8859-1不支持中文,所以不管浏览器在解码的时候用的是什么字符集编码,在浏览器上的都是乱码。
4.补充PrintWriter
PrintWriter不管是多个对象,都是一样的,举例:
PrintWriter out = response.getWriter();
PrintWriter out1 = response.getWriter();
if(out==out1){
out.print("同一个输出流对象");
}
5.print和println方法的不同
(1)Println和print的不同是println有换行的作用
(2)Print和println的换行的作用只对源文件有作用,而对浏览器没有作用,要在浏览器中换行,要用<br/>标签换行。
四 输出缓冲区
1.输出缓冲区的介绍
(1)Servlet程序输出的HTTP消息的响应正文首先被写入到Servlet引擎提供的一个输出缓冲区中,直到输出缓冲区被填满或者Servlet程序已经写入了所有的响应内容,缓冲区中的内容才会被Servlet引擎发送到客户端。
(2)使用输出缓冲区后,Servlet引擎就可以将响应状态行、各响应头和响应正文严格按照HTTP消息的位置顺序进行调整后再输出到客户端。
(3)如果在提交响应到客户端时,输出缓冲区中已经装入了所有的响应内容,Servlet引擎将计算响应正文部分的大小并自动设置Content-Length头字段。
(4)如果在提交响应到客户端时,输出缓冲区中装入的内容只是全部响应内容的一部分,Servlet引擎将使用HTTP1.1的chunked编码方式(通过设置 Transfer-Encoding头字段来指定)传输响应内容。
2.输出缓冲区的有关方法
//读取缓存区的大小
System.out.println(response.getBufferSize());
//设置缓冲区的的大小,会小与你设置的值
response.setBufferSize(1024);
System.out.println(response.getBufferSize());
//填满缓冲区
int len=response.getBufferSize();
//System.out.println(len);
for(int i =0;i<len;i++){
System.out.println("w");
}
3.实例----动态文件内容的下载
//动态的文件的下载
response.setContentType("application/x-msdownload");
//Content-Disposition文件的位置 response.setHeader("Content-Disposition","attachment;filename=aa.txt");
ServletOutputStream sos = response.getOutputStream();
sos.write("hello".getBytes());//动态的生成下载的内容
sos.close();