首先咱們認識下什麼是cookies:java
cookie其實是一個存在你硬盤裏的數據,可是這些數據很特殊,只能由web應用提交給瀏覽器幫助存儲,而且咱們還能讀取瀏覽器存在本地的cookieweb
web應用通常只在cookie中存儲一些用戶信息等少許且暫時的數據,數據量大則不適合存儲在cookies瀏覽器
通常瀏覽器對於每一個web應用會分別給予他們40個cookie用來存儲數據,而且每一個cookie的大小不超過4K(據說部分瀏覽器的cookie能存很大的數據,不過咱們通常不會存這麼大的數據,由於數據提取的效率不高,影響性能)tomcat
說了這麼多廢話,而後重點終於來了cookie
java經過httpServletRequest接口來訪問瀏覽器請求中的cookies數據(這裏先了解一下cookies前因後果,代碼待會一併給出)性能
每一個cookie有兩個屬性:鍵 ,值(無特定格式字符串,因此能夠diy存數據,不過要注意URL編碼問題,編碼問題待會和代碼一同講)編碼
若是咱們須要存儲新的cookie咱們能夠new一個cookie實例 並經過httpservletRsponse提交到瀏覽器,進而存儲到本地spa
下面給出cookie的一個通用類code
/* * 該類能夠從瀏覽器請求中提取出cookies並進行對cookis的相關操做 * */ public class CookiesUtil extends BaseController { /** * 根據名字獲取cookie * * @param request * @param name * cookie名字 * @return */ 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 */ 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 * servlet請求 * @param value * 保存值 * @author jxf */ 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; }
有了上面的通用類咱們能夠讀取和新建cookie了,在這裏我還要提一點:新建cookie的名字若是瀏覽器已經存在,則再也不重複添加,會覆蓋以前的cookie對象
瀏覽器如何查看請求的cookie和返回的cookie呢?拿Google瀏覽器舉個栗子
而後就是咱們可能須要對cookie進行刪除操做
1 /** 2 * <p>刪除無效cookie</p> 3 * <p>無效☞1.過期 2.未發佈</p> 4 * @param request 5 * @param response 6 * @param list 7 */ 8 private void delectCookieByName(HttpServletRequest request, HttpServletResponse response,String deleteKey) throws NullPointerException {
12 Map<String, Cookie> cookieMap = ReadCookieMap(request);
17 for (String key : cookieMap.keySet()) { 18 if(key==deleteKey && key.equals(deleteKey)) { 19 Cookie cookie = cookieMap.get(key);
21 cookie.setMaxAge(0);//設置cookie有效時間爲0 22 cookie.setPath("/");//不設置存儲路徑 23 response.addCookie(cookie); 24 } 25 } 26 }
注意刪除cookie必須同時具有時間和路徑的參數否則部分瀏覽器刪除不了
最後,不得不提一下,寫了這麼多,對你有用就給個贊!!!