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
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) {
 
     //..
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值