Java实现对cookie的增删改查

原创 2016年08月30日 11:46:24
1.springMVC框架:
         /**
         * 读取所有cookie
         * 注意二、从客户端读取Cookie时,包括maxAge在内的其他属性都是不可读的,也不会被提交。浏览器提交Cookie时只会提交name与value属性。maxAge属性只被浏览器用来判断Cookie是否过期
         * @param request
         * @param response
         */
        @RequestMapping("/showCookies")
        public void showCookies(HttpServletRequest request,HttpServletResponse response ){
             
            Cookie[] cookies = request.getCookies();//这样便可以获取一个cookie数组
            if (null==cookies) {
                System.out.println("没有cookie=========");
            } else {
                for(Cookie cookie : cookies){
                    System.out.println("name:"+cookie.getName()+",value:"+ cookie.getValue());
                }
            }
             
        }
         /**
         * 添加cookie
         * @param response
         * @param name
         * @param value
         */
        @RequestMapping("/addCookie")
        public void addCookie(HttpServletResponse response,String name,String value){
            Cookie cookie = new Cookie(name.trim(), value.trim());
            cookie.setMaxAge(30 * 60);// 设置为30min
            cookie.setPath("/");
            System.out.println("已添加===============");
            response.addCookie(cookie);
        }
        /**
         * 修改cookie
         * @param request
         * @param response
         * @param name
         * @param value
         * 注意一、修改、删除Cookie时,新建的Cookie除value、maxAge之外的所有属性,例如name、path、domain等,都要与原Cookie完全一样。否则,浏览器将视为两个不同的Cookie不予覆盖,导致修改、删除失败。
         */
        @RequestMapping("/editCookie")
        public void editCookie(HttpServletRequest request,HttpServletResponse response,String name,String value){
            Cookie[] cookies = request.getCookies();
            if (null==cookies) {
                System.out.println("没有cookie==============");
            } else {
                for(Cookie cookie : cookies){
                    if(cookie.getName().equals(name)){
                        System.out.println("原值为:"+cookie.getValue());
                        cookie.setValue(value);
                        cookie.setPath("/");
                        cookie.setMaxAge(30 * 60);// 设置为30min
                        System.out.println("被修改的cookie名字为:"+cookie.getName()+",新值为:"+cookie.getValue());
                        response.addCookie(cookie);
                        break;
                    }
                }
            }
             
        }
        /**
         * 删除cookie
         * @param request
         * @param response
         * @param name
         */
        @RequestMapping("/delCookie")
        public void delCookie(HttpServletRequest request,HttpServletResponse response,String name){
            Cookie[] cookies = request.getCookies();
            if (null==cookies) {
                System.out.println("没有cookie==============");
            } else {
                for(Cookie cookie : cookies){
                    if(cookie.getName().equals(name)){
                        cookie.setValue(null);
                        cookie.setMaxAge(0);// 立即销毁cookie
                        cookie.setPath("/");
                        System.out.println("被删除的cookie名字为:"+cookie.getName());
                        response.addCookie(cookie);
                        break;
                    }
                }
            }
        }


2.一般情况下,会首先对cookie进行封装:
/**
     * 根据名字获取cookie
     * @param request
     * @param name cookie名字
     * @return
     */
    public  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  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;
    }
版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

Java实现对cookie的操作(增删改查)

/**          * 读取所有cookie          * 注意二、从客户端读取Cookie时,包...

php 设置cookie修改cookie

php里设置cookie setCookie('seckillPhone',‘13277777777’,time()+30*24*60*60,'/'); 如果想要修改cookie的值,任然使用set...

Java对cookie的简单操作

java对cookie的操作比较简单,主要介绍下建立cookie和读取cookie,以及如何设定cookie的生命周期和cookie的路径问题。   建立一个无生命周期的cookie,即随着浏览器...

JavaWeb--使用cookie实现会话管理

一、会话的概念   会话可简单理解为:用户开一个浏览器,点击多个超链接,访问服务器多个web资源,然后关闭浏览器,整个过程称之为一个会话。   有状态会话:一个同学来过教室,下次再来教室,我们会知道这...

java Cookie 设置和读取

1.设置cookie到客户端         Cookie c1 = new Cookie("username","hzh");       &#...

java操作Cookie,进行添加、读取、删除操作

Java操作Cookie之添加Cookie:  Cookie cookie = new Cookie("name", "aotori"); //(key,value) cookie....
  • foart
  • foart
  • 2009-07-26 15:04
  • 13928

Java Web如何操作Cookie的添加修改和删除

一、Cookie是什么Cookie是服务器存放在客户端浏览器上的一些小数据,可以使用Cookie完成与服务器的一些交互动作。服务器可以通过HTTP响应头将Cookie发送给浏览器,而浏览器如果支持存储...

JavaWeb-09(HttpServletRequest对象&会话管理之Cookie)

JAVAWEB-09:HttpServletRequest对象&会话管理之Cookie HttpServletRequest 一、HttpServletRequest对象: 代表客户端的请求...

httpServletRequest获取浏览器的cookie

1.方法: 当在设置问cookie后利用response添加cookie,响应给浏览器,当下次访问服务器是,request携带cookie到服务器 ,使用 req.getCookies();得到coo...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)