Chrome查看Cookie的按钮如下图所示:
Cookie查看页面如下图所示:
可以重点关注红框标注的几个信息:
- Cookie的名称;
- Cookie的值;
- Cookie的过期时间。
Cookie相关属性
name:Cookie的名称;
value:Cookie的值;
comment:Cookie的注释;
domain:可以看到Cookie的域;
maxAge:Cookie的失效时间;正值表示Cookie会在指定的时间后过期,负值表示浏览器关闭的时候过期,0会导致Cookie被删除;
path:可以看到Cookie的URL;
secure:是否需要使用安全连接来传输;
version:版本;
isHttpOnly:HttpOnly的Cookie将不会暴露给客户端的脚本代码;
PS:需要注意的是,Cookie的名称要符合标识符的命名规则,同时不允许为【Comment,Discard,Domain,Expires,Max-Age,Path,Secure,Version】这几个关键字,也不允许以“$”开头。
Cookie的增删改查
Cookie创建后通过HttpServletResponse添加。
public static void addCookie(HttpServletResponse response, String name, String value, int maxAge) {
Cookie cookie = new Cookie(name, value);
cookie.setPath("/");
if (maxAge > 0) {
cookie.setMaxAge(maxAge);
}
response.addCookie(cookie);
}
Cookie通过HttpServletRequest获取,如下获取全部Cookie并以Map形式存储。
private static Map<String, Cookie> readCookieMap(HttpServletRequest request) {
Map<String, Cookie> cookieMap = new HashMap<>();
Cookie[] cookies = request.getCookies();
if (cookies != null) {
for (Cookie cookie : cookies) {
cookieMap.put(cookie.getName(), cookie);
}
}
return cookieMap;
}
删除Cookie的时候将Cookie的MaxAge置为0后重新添加到HttpServletResponse即可。
public static void deleteCookie(HttpServletRequest request, HttpServletResponse response, String name) {
Map<String, Cookie> cookieMap = readCookieMap(request);
if (cookieMap.containsKey(name)) {
Cookie cookie = cookieMap.get(name);
cookie.setMaxAge(0);
response.addCookie(cookie);
}
}