Servlet是Java Web应用中最核心的组件,也是Web服务器组件,它是一个中间控制层,负责处理客户端提交过来的请求数据以及调用业务逻辑对象,根据业务逻辑来控制页面转发。下面是一个写Cookie的小例子:
当输入用户名和密码并提交到Servlet中,在Servlet中将用户名添加到Cookie对象中,然后关闭浏览器,重新访问用户登录页时,用户的文本框会显示上一次输入的用户名信息。
Servlet API中提供了Cookie类,用户把表单提交到Servlet后,在Servlet中获取用户请求的信息,并添加到Cookie对象中,再通过HttpServletResponse对象把Cookie信息返回给客户端,然后在JSP页面中通过request内置对象来获取客户端的Cookie信息。
在JSP中使用request对象获取的是一个Cookie对象的数组,需要在循环中遍历所有的Cookie对象,并通过Cookie对象的getName()方法查找所有的Cookie对象名称,然后根据找到的Cookie名称获得Cookie对象的值。
方法 | 说明 |
GetComment()/setComment(String purpose) | 获取/设置Cookie的注释 |
GetDomain()/setDomain(String parrern) | 获取设置Cookie适用的域 |
GetMaxAge()/stMaxAge(int expiry) | 获取/设置Cookie过期之前的时间,以秒为单位。如果不设置该值,则Cookie只在当前会话内有效 |
GetName()/setName(String name) | 获取/设置Cookie的名字 |
GetValue/setValue(String newValue) | 获取/设置Cookie的值 |
GetPath()/setPath(String uri) | 获取/设置Cookie适用的路径 |
过程为:
1. 新建web项目,在index中写标签。
<form action="cookieservlet" method="post">
用户名:<input type="text" name="name" value="<% if(userName !=null){out.print(userName);}%>"><br>
密 码:<input type="text" name="pwd"><br>
<input type="submit" value="登录">
</form>
2.新建CookieServlet的Servlet类,继承HttpServlet,在该类的doPost()方法中获取用户名信息,添加到Cookie中并保存到客户端。
package com.lhg.servlet;
import java.io.IOException;
import javax.servlet.ServletException;
import javax.servlet.http.Cookie;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
public class CookieServlet extends HttpServlet {
@Override
protected void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
request.setCharacterEncoding("UTF-8");
String name=request.getParameter("name"); //获得用户名
name=java.net.URLEncoder.encode(name,"UTF-8"); //将用户名进行格式编码
Cookie nameCookie = new Cookie("userName", name); //创建一个Cookie对象,并将用户名保存到Cookie对象中
nameCookie.setMaxAge(60) ; //设置Cookie的过期之前的时间,单位为秒
response.addCookie(nameCookie); //通过response的addCookie()方法将此Cookie对象保存到客户端的Cookie中
request.getRequestDispatcher("success.jsp").forward(request, response);
}
}
3.在index.jsp页中读取所有客户端的Cookie,通过循环Cookie数组找到保存用户名的Cookie
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
String userName =null;
Cookie cookieArr[] =request.getCookies(); //用于保存从Cookie中读取的用户名
if(cookieArr != null && cookieArr.length >0 ){
for(Cookie c : cookieArr){
//如果Cookie中有一个名为userName的cookie
if(c.getName().equals("userName")){
userName=URLDecoder.decode(c.getValue(),"UTF-8"); //将字符串解码,获得此Cookie的值
}
}
}
%>
4.将获取到的用户名Cookie的值赋值给“用户名“文本框
用户名:<input type="text" name="name" value="<% if(userName !=null){out.print(userName);}%>">
5.在web.xml文件中配置CookieServlet类
<span style="font-size:18px;"> <servlet>
<servlet-name>CookieServlet</servlet-name>
<servlet-class>com.lhg.servlet.CookieServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>CookieServlet</servlet-name>
<url-pattern>/cookieservlet</url-pattern>
</servlet-mapping></span>
在创建Cookie对象时,由于不可以直接将中文字符作为Cookie中的值,因此在将中文字符保存到Cookie对象之前,应该使用java.net.URLEncoder类的encode()方法对中文字符进行编码。在获取该Cookie对象中的值时,需要使用java.net.URLDecoder类的decode()方法对已经编码过的字符串进行编码,还原字符串的初始值。
这样就可以通过保存的Cookie对用户进行验证等相关的操作。