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);
}
}