上一次写到Servlet的实现方法,主要还是通过继承HttpServlet来实现Servlet。下面主要是回顾一下HttpServletRequest和HttpServletResponse对象中的一些方法。因为Web服务器收到客户端的http请求,会针对每一次请求创建一个用于代表请求的request的对象,和代表响应的response对象。
1.HttpServletResponse
设置响应状态码:setStatus(int )
请求重定向:sendRedirect(String location)
设置响应消息头:setHeader(String name, String value)
eg, response.setHeader("content-type","text/html;charset=UTF-8")
告知浏览器使用什么码表,即让浏览器用UTF-8来解析返回的数据
设置服务器端编码:setCharacterEncoding(String charset)
eg, response.setCharacterEncoding("UTF-8");
告知服务器(servlet)用UTF-8来转码,而不是用ISO-8859-1(服务器端默认编码)
设置客户端和服务器端编码:setContentType(String charset)
setHeader和setCharacterEncoding的优化,同时告诉客户端和服务器端使用什么格式的编码。
获得字符输出流:getWrite()
获得字节输出流:getOutputStream()//注意编码
2.HttpServletRequest
获得请求方式:getMethod();//post or get
获得客户端发出请求时完整的url:getRequestURL();
获得请求行中的uri:getRequestURI();
获得当前应用的虚拟目录:getContextPath();
获得请求行中的参数部分:getQueryString();
根据请求消息头的名称获得其对应的值:getHeader(String name);
以下是关于请求正文方面的方法,比较重要
<input type="text" name="username"/>
getParameter(String name);根据表单中name属性的名,获取value值
getParameterValues(String name)为复选框提供的获得值得方法
getParameterNames();获取表单提交的所有name名称
getParameterMap();得到表单提交的所有的键值
因为request也是一个域对象,所以有以下方法
setAttribute(String name, Object value);
getAttribute(String name);
removeAttribute(String name);
请求转发相关:(注意:请求转发不能转发到其他路径,必须是本项目之下的,而重定向可以到其他路径)
getRequestDispatcher(String path)//获得一个RequestDispatcher对象
forword(ServletRequest , ServletResponse )//转发
include(ServletRequest , ServletResponse )//请求包含
解决post方式编码问题:
request.setCharacterEncoding("UTF-8");//告诉服务器要使用什么编码,注:浏览器是用什么编码传到服务器端就是什么编码
解决get方式编码问题:
byte b[] = name.getBytes("ISO-8859-1");//1010101
String name = new String(b,"UTF-8");//解决
即:String name = new String(name.getBytes("ISO-8859-1"),"UTF-8");
以下回顾Cookie和Session。
3.Cookie
cookie是servlet发送到web浏览器的少量信息,这些信息由浏览器保存,然后发送回服务器。cookie的值可以唯一的标识客户端。因此,cookie常用于会话管理。一个cookie拥有一个键、值和一些可选属性(注释,路径,域限定符、版本号)。Servlet通过视同HttpServletResponse的addCookie方法,将创建的cookie发送到客户端浏览器,该方法将字段添加到HTTP响应头,以便于一次一个地将cookie发送到浏览器。而客户端浏览器通过向HTTP响应头添加字段将cookie返回给服务器端(即servlet),可使用HttpServletRequest的getCookie方法从请求中获取cookie。注意,一些cookie可能有相同的键,但却有不同的路径属性。
属性:
(1)name:相当于键。名称不能唯一确定一个Cookie。因为cookie的路径可能不同。
(2)value:值。
(3)path:默认值是写cookie所在的应用程序的访问路径。(客户端在访问服务器资源时,根据访问的路径决定是否带着cookie到服务器,如果访问的路径是以cookie所在的path,就带着cookie,否则不带)。
(4)maxAge:cookie的缓存时间。默认-1(存在浏览器的内存中)。通过setMaxAge(int )来设置缓存时间。(可实现记住用户的功能)
负数:cookie的数据存在浏览器缓存中
0:删除。
整数:缓存到磁盘上的时间。(单位s)
4.Session
session也是一个域对象。(目前已知的域对象:ServletContext,request,Session)。sesseion可以使处在同一个会话下的应用共享数据。cookie是客户端技术,只能存字符串。HttpSession是服务器端技术,可以存对象。
通过getSession()获得Session对象。
HttpSession request.getSession()内部执行原理:
(1)获取名称为JSESSIONID的cookie的值。(session是依赖于cookie的)
(2)如果没有这样的cookie,就创建一个新的httpsession对象,并分配一个唯一的SessionID,并向客户端返回一个键值为JSESSIONID=SessionID的cookie。
(3)如果有这样的cookie,获取cookie的值(即HttpSession对象的值),从服务器内存中根据ID找到HttpSession对象。
找到了:取出来继续服务。
找不到:从(2)开始。
方法:
setAttribute(String )
getAttribute(String )