如题,大家在使用各种网站时,为了更好的用户体验,网站往往会提供这两种功能之一,以便下次登录方便。


今天要讲述的是用java操作cookie来实现这两个功能,网络上也有很多的总结,这里只作为自己知识点的一个记录。其实这两个功能是大同小异的,其核心就是java怎么对cookie进行增加、修改、删除的操作。
1. 创建cookie
Cookie cookie = new Cookie(name, value);// 两个参数全是字符串
response.addCookie(cookie);上面的cookie没有生命周期,随着浏览器关闭就消失,生存在浏览器内存里。Cookie cookie = new Cookie(name, value);
cookie.setMaxAge(maxAge);// 这里需要一个整型值,单位为秒
cookie.setPath("/"); // 设置cookie路径,/代表根路径,该cookie对整个网站都有效,如果不设置路径,只有创建该cookie的路径及其子路径可以访问该cookie
response.addCookie(cookie);上面的cookie声明周期为maxAge。2. 读取cookie
Cookie[] cookies = request.getCookies();3. 修改cookie遍历cookie数组,根据name找到相应的cookie对象,修改之,然后放到response中.
4. 删除cookie
Cookie cookie = new Cookie(name, null);
cookie.setMaxAge(0);// 设置为0,立即删除该cookie
response.addCookie(cookie);cookie的简单操作就介绍完了,我们来建立一个cookie的管理类,把相关的操作封装到一个对象中,这也是面向对象的思想吧,请看代码.
/**
* 管理cookie
*
*/
public class CookieManager {
/** 保存cookie的map */
private static Map<String,Cookie> cookieMap = new HashMap<String,Cookie>();
/** 用户名key */
public static final String USERNAME = "username";
/** 密码key */
public static final String PASSWORD = "password";
/** 是否保存的key */
public static final String ISSAVE = "isSave";
/**
* 设置cookie
* @param response
* @param name cookie名字
* @param value cookie值
* @param maxAge cookie生命周期 以秒为单位
*/
public static void addCookie(HttpServletResponse response, String name, String value, int maxAge) {
Cookie cookie = new Cookie(name, value);
cookie.setMaxAge(maxAge);
response.addCookie(cookie);
}
/**
* 根据名字获取cookie
* @param name cookie名字
* @return
*/
public static Cookie getCookieByName(String name) {
if(cookieMap.containsKey(name)) {
Cookie cookie = (Cookie)cookieMap.get(name);
return cookie;
} else {
return null;
}
}
/**
* 将cookie封装到Map里面
* @param request
* @return
*/
public static void readCookieMap(HttpServletRequest request) {
cookieMap.clear();
Cookie[] cookies = request.getCookies();
if(cookies != null) {
for(Cookie cookie : cookies) {
cookieMap.put(cookie.getName(), cookie);
}
}
}
}那么接下来就简单了,每次登陆之前,先调用readCookieMap来初始化,如果是自动登录,直接拿这个用户名和密码去登录,如果是记住用户,那么把用户名和密码填写到输入框,当然我这里用户名和密码写入cookie时都没有加密。