java對cookie的操作

java對cookie的操作比較簡單,主要介紹下建立cookie和讀取cookie,以及如何設定cookie的生命週期和cookie的路徑問題。

 

建立一個無生命週期的cookie,即隨着瀏覽器的關閉即消失的cookie,代碼如下

1
2
3
4
HttpServletRequest request 
HttpServletResponse response
Cookie cookie = new Cookie("cookiename","cookievalue");
response.addCookie(cookie);

 

下面建立一個有生命週期的cookie,可以設置他的生命週期

1
2
3
4
5
6
7
8
cookie = new Cookie("cookiename","cookievalue");
 
cookie.setMaxAge(3600);
 
//設置路徑,這個路徑即該工程下都可以訪問該cookie 如果不設置路徑,那麼只有設置該cookie路徑及其子路徑可以訪問
 
cookie.setPath("/");
response.addCookie(cookie);

 

下面介紹如何讀取cookie,讀取cookie代碼如下

1
2
3
4
5
Cookie[] cookies = request.getCookies();//這樣便可以獲取一個cookie數組
for(Cookie cookie : cookies){
    cookie.getName();// get the cookie name
    cookie.getValue(); // get the cookie value
}

 

上面就是基本的讀寫cookie的操作。我們在實際中最好進行一下封裝,比如增加一個cookie,我們關注的是cookie的name,value,生命週期,所以進行封裝一個函數,當然還要傳入一個response對象,addCookie()代碼如下

1
2
3
4
5
6
7
8
9
10
11
12
13
/**
 * 設置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.setPath("/");
    if(maxAge>0)  cookie.setMaxAge(maxAge);
    response.addCookie(cookie);
}

 

讀取cookie的時候,爲了方便我們的操作,我們希望封裝一個函數,只要我們提供cookie的name,我們便可以獲取cookie的value,帶着這個想法,很容易想到將cookie封裝到Map裏面,於是進行下面的封裝

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
/**
 * 根據名字獲取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;
}


登錄時寫Cookie: 
Java代碼  收藏代碼
  1. public void setLoginIDCookie1(HttpServletResponse response, String value) {  
  2.         Cookie cookie = new Cookie(loginIdCookieKey, value);  
  3.         // 設置cookie的域,如果不設置該屬性將不能夠寫入cookie  
  4.         if (!StringUtils.isBlank(domain)) {  
  5.             cookie.setDomain(domain);  
  6.         }  
  7.         // 設置cookie的路徑,這個路徑即改工程下都可以訪問該cookie 如果不設置路徑,那麼只有設置該cookie的路徑及其子路徑可以訪問  
  8.         if (!StringUtils.isBlank(path)) {  
  9.             cookie.setPath(path);  
  10.         }  
  11.         // 設置cookie的過期時間(單位秒)  
  12.         if (expiry > 0) {  
  13.             cookie.setMaxAge(expiry);  
  14.         }  
  15.         response.addCookie(cookie);  
  16.     }  




登出時,刪除Cookie:
 
Java代碼  收藏代碼
  1. public void deleteLoginCookies(HttpServletRequest request, HttpServletResponse response) {  
  2.        Cookie[] cookies = request.getCookies();  
  3.        if (cookies != null && cookies.length > 0) {  
  4.            // 遍歷瀏覽器發送到服務器端的所有Cookie,找到自己設置的Cookie  
  5.            for (Cookie cookie : cookies) {  
  6.                String cookieName = cookie.getName();  
  7.                if (cookieName.equals(loginIdCookieKey)) {  
  8.                    // 設置Cookie立即失效  
  9.                    cookie.setMaxAge(0);  
  10.                    /** 
  11.                     * 刪除Cookie時,只設置maxAge=0將不能夠從瀏覽器中刪除cookie, 
  12.                     * 因爲一個Cookie應當屬於一個path與domain,所以刪除時,Cookie的這兩個屬性也必須設置。 
  13.                     *  
  14.                     * 誤區:剛開始時,我沒有發現客戶端發送到服務器端的cookie的path與domain值爲空這個問題。 
  15.                     * 因爲在登陸系統時,我設置了Cookie的path與domain屬性的值,就誤認爲每次客戶端請求時,都會把Cookie的 
  16.                     * 這兩個屬性也提交到服務器端,但系統並沒有把path與domain提交到服務器端(提交過來的只有Cookie的key,value值)。 
  17.                     */  
  18.                    // 重點是這裏1,必須設置domain屬性的值  
  19.                    cookie.setDomain(domain);  
  20.                    // 重點是這裏2,必須設置path屬性的值  
  21.                    cookie.setPath(path);  
  22.                    response.addCookie(cookie);  
  23.                }  
  24.            }  
  25.        }  
  26.    }  
try{ 
        Cookie cookie = new Cookie("username", URLEncoder.encode(tuser,"utf-8")); 
        cookie.setMaxAge(60 * 60 * 24 * 30 * 2); //用戶名保留2個月 
        response.addCookie(cookie); 
    }catch(Exception ex){ 
        ex.printStackTrace(); 
    } 
再次走登錄流程時,先獲取Cookie中的該參數,參數任然有效時,直接取出 
try{ 
        Cookie[] cookies = request.getCookies(); 
        if(cookies != null){//取用戶登錄名 
            for(int i = 0; i < cookies.length; i++){ 
                if(cookies[i].getName().equals("username")){ 
                    String username = URLDecoder.decode(cookies[i].getValue(), "utf-8"); 
                } 
            } 
        } 
    }catch(Exception e){ 
        e.printStackTrace(); 
    } 
Spring MVC Cookie example
importorg.springframework.web.bind.annotation.CookieValue;
importorg.springframework.web.bind.annotation.RequestMapping;
//..
@RequestMapping("/hello.html")
publicString hello(
    @CookieValue(value = "foo", defaultValue = "hello") String fooCookie) {
 
    //..
}

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章