1、 WEB服务器回送给WEB客户端的HTTP响应消息分为三个部分:
(1)状态行
(2)响应消息头
(3)消息正文(也叫实体内容)
2、 Servlet API中定义的ServletResponse接口类用于创建响应消息。
3、 HttpServletResponse是专用于HTTP协议的ServletResponse子接口,它用于封装HTTP响应消息。
4、 HttpServletResponse定义了一系列用于描述各种HTTP状态码的常量。
5、 在service()方法内部调用HttpServletResponse对象的各种方法来创建响应消息。
产生响应状态行
1、 HTTP响应消息的响应状态行包括HTTP版本、状态代码和一条相关的提示信息:
HTTP/1.1 200 OK
2、 HttpServletResponse中定义了若干与状态码数值对应的常量,每个常量的名称以前缀SC(Status Code的简写)开头,然后是状态码在HTTP 1.1规范中所表示的状态信息的英文单词的组合,每个单词之间用下划线连接,且所有字母都大写。
状态码404 对应的常量为HttpServletResponse.SC_NOT_FOUND
3、 setStatus方法用于设置HTTP响应消息的状态码,并生成响应状态行。
4、 sendError方法用于发送表示错误信息的状态码(一般是404,找不到客户机所请求的资源)到客户端,并清除缓冲区中的内容。
响应消息头的实用案例
Servlet的中文输出问题
原理:
1、 浏览器接收到的中文字符并不是中文符号本身,而是它的某种字符集编码的数据。
2、 浏览器必须使用正确的字符集编码进行查看,才能将它所接收到的数据显示为正确的中文字符。
3、 当Servlet程序仅仅需要输出纯文本格式的响应正文时,通常应调用ServletResponse对象的getWriter方法返回一个PrintWriter对象,然后使用这个PrintWriter对象将文本内容写入到客户端。
4、 Java程序中的字符文本在内存中是以unicode编码的形式存在的,PrintWriter对象在输出字符文本时,需要先将它们转换成其他某种字符集编码的字节数组后输出。
5、 ServletResponse对象的getWriter方法返回的PrintWriter对象默认使用ISO8859-1字符集编码进行Unicode 字符串到字节数组的转换,由于ISO8859-1字符集中根本就没有中文字符,Unicode编码的中文字符将被转换成无效的字符编码后输出给客户端。
解决办法:
1、 ServletResponse接口中定义了setCharacterEncoding、setContentType和setLocale等方法来指定 ServletResponse.getWriter方法返回的PrintWriter对象所使用的字符集编码。
2、 调用ServletResponse接口中定义的setContentType方法,在HTTP响应消息的Content-Type头字段中指定响应正文的字符集编码。
response.setContentType("text/html;charset=utf-8");
Html文档
浏览器对请求参数中的字符(中国)的某种字符集编码(utf-8)进行了url编码
中 utf-8的编码是E4B8AD ——>url编码
请求消息发送到web服务器
Web服务器从请求消息把每一个参数名和参数值分离出来
对每一个参数名和参数值针对某种字符集编码()进行url解码(解码后是字节数组E4 B8 AD)——按照某种字符集编码(utf-8)(中)
让浏览器定时刷新网页
1、 HTTP协议中定义了一个Refresh头字段,用于告诉浏览器过多少秒后自动刷新页面。
2、 在Refresh头字段的时间设置值后面还可以用分号(;)分隔后,再指定一个URL地址,这将让浏览器在指定的时间值后自动去访问该URL地址指向的资源。
response.setHeader("Refresh","2);
禁止浏览器缓存当前文档内容
//以下3条语句是设置浏览器不缓存,因为各个浏览器的支持不同,所以写3个
response.setDateHeader("Expires",0 );
response.setHeader("Cache-Controll","no-cache");
response.setHeader("pragma","no-cache");