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:
登出時,刪除Cookie:
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(); }
import org.springframework.web.bind.annotation.CookieValue; import org.springframework.web.bind.annotation.RequestMapping; //.. @RequestMapping ( "/hello.html" ) public String
hello( @CookieValue (value
= "foo" ,
defaultValue = "hello" )
String fooCookie) { //.. } |