HttpServletRequest:增刪改查cookie
阿新 • • 發佈:2018-11-09
什麼是cookies:
cookie實際上是一個存在你硬盤裡的資料,但是這些資料很特殊,只能由web應用提交給瀏覽器幫助儲存,並且我們還能讀取瀏覽器存在本地的cookie
web應用一般只在cookie中儲存一些使用者資訊等少量且暫時的資料,資料量大則不適合儲存在cookies
cookie的操作:
新增cookie
Cookie cookie = new Cookie(“”,“”);
第一個引數是cookie的名字,第二個引數是cookie的值,如果值是中文,要使用URLEncoder.encode("","")進行編碼:
URLEncoder.encode("","")的第一個引數是value,第二個引數是:編碼方式
cookie的訪問路徑:
因為不是所有的cookie都能夠被其他的servlet訪問,所以要設定訪問的路徑許可權;
cookie.setPath("");預設值是專案路徑下;
裡面的路徑是以專案名+要被訪問的 url-pattern的絕對路經;
設定cookie的存在時間
cookie.setMaxAge(secn); 引數是秒;
預設值是-1,即:關閉瀏覽器時就清除cookie;
當設定為0的時候:建立完cookie,使用後馬上就 刪除;
因為時間到了,又因為,cookie沒有清除方法,所以設定為 0,就相當於清除方法;
當設定時間大於0,當時間到達後就會自動刪除
cookie注意事項:
cookie只能儲存少量的資料,大約4K;
cookie可以被客戶禁用,所以使用應該注意
cookie安全性比較低,敏感資訊不要放在其中,而且注意要加密
cookie只能儲存字串
cookie的數量有限制
cookie工具類:
package com.newcapec.util.sys; import javax.servlet.http.Cookie; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import java.io.UnsupportedEncodingException; import java.net.URLEncoder; import java.util.HashMap; import java.util.Map; /** * @Title: cookis的相關操作 * @ClassName: com.newcapec.util.sys.CookiesUtil.java * @Description: * * @Copyright 2016-2018 - Powered By 研發中心 * @author: FLY * @date: 2018-11-02 15:56 * @version V1.0 */ public class CookiesUtil { /** * 根據名字獲取cookie * * @param request * @param name cookie名字 * @return Cookie */ public static Cookie getCookieByName(HttpServletRequest request, String name) { Map<String, Cookie> cookieMap = ReadCookieMap(request); if (cookieMap.containsKey(name)) { Cookie cookie = (Cookie) cookieMap.get(name); return cookie; } else { return null; } } /** * 將cookie封裝到Map裡面 * * @param request * @return Map<String, Cookie> */ private static Map<String, Cookie> ReadCookieMap(HttpServletRequest request) { Map<String, Cookie> cookieMap = new HashMap<String, Cookie>(); Cookie[] cookies = request.getCookies(); if (null != cookies) { for (Cookie cookie : cookies) { cookieMap.put(cookie.getName(), cookie); } } return cookieMap; } /** * 儲存Cookies * * @param response response響應 * @param name cookie的名字 * @param value cookie的值 * @param time cookie的存在時間 */ public static HttpServletResponse setCookie(HttpServletResponse response, String name, String value, int time) { // new一個Cookie物件,鍵值對為引數 Cookie cookie = new Cookie(name, value); // tomcat下多應用共享 cookie.setPath("/"); // 如果cookie的值中含有中文時,需要對cookie進行編碼,不然會產生亂碼 try { URLEncoder.encode(value, "utf-8"); } catch (UnsupportedEncodingException e) { e.printStackTrace(); } // 單位:秒 cookie.setMaxAge(time); // 將Cookie新增到Response中,使之生效 response.addCookie(cookie); // addCookie後,如果已經存在相同名字的cookie,則最新的覆蓋舊的cookie return response; } /** * <p>刪除無效cookie</p> * <p>無效☞1.過時 2.未釋出</p> * * @param request 請求 * @param response 響應 * @param deleteKey 需要刪除cookie的名稱 */ private void delectCookieByName(HttpServletRequest request, HttpServletResponse response, String deleteKey) throws NullPointerException { Map<String, Cookie> cookieMap = ReadCookieMap(request); for (String key : cookieMap.keySet()) { if (key == deleteKey && key.equals(deleteKey)) { Cookie cookie = cookieMap.get(key); // 預設值是-1,即:關閉瀏覽器時就清除cookie; // 當設定為0的時候:建立完cookie,使用後馬上就刪除; // 因為時間到了,又因為,cookie沒有清除方法,所以設定為 0,就相當於清除方法; // 當設定時間大於0,當時間到達後就會自動刪除 cookie.setMaxAge(0);//設定cookie有效時間為0 cookie.setPath("/");//不設定儲存路徑 response.addCookie(cookie); } } } }
新增一個cookie
執行效果