cookie基本知识

cookie

  • 什么是cookie:

    1. cookie是服务器通知客户端保存键值对的一种技术。

    2. 客户端有了cookie后每次请求都发送给服务器

    3. 每个cookie的大小不能超过4KB

  • cookie的工作过程

    1. 服务器创建cookie对象
    2. 调用response.addCookie(cookie)告诉客户端保存cookie,并在响应行里面显示Set-Cookie:key=value
    3. 客户端收到响应后查看有没有cookie,有的话就将其保存起来
protected void createCookie(HttpServletRequest req, HttpServletResponse resp){
        //1.创建cookie对象
        Cookie cookie = new Cookie("key2","value2");
        //2.通知客户端保存cookie对象
        resp.addCookie(cookie);
        try {
            resp.getWriter().write("创建成功");
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
  • 服务器如何获取Cookie:

    ​ 服务器通过request.getCookies():cookie[]就能将客户端发送的所以cookie

 protected void getCookie(HttpServletRequest req,HttpServletResponse resp) throws IOException {
        //获取cookie
        Cookie[] cookies = req.getCookies();
        for (Cookie cookie : cookies) {
            try {
                //getName返回cookie的键
                //getValue返回cookie的值
                resp.getWriter().write("Cookie["+cookie.getName()+"="+cookie.getValue()+"]<br/>");
            } catch (IOException e) {
                e.printStackTrace();
            }
            System.out.println(cookie);
        }
}
  • Cookie的修改

    ​ 方案一:

    1. 先创建一个要修改的同名的cookie对象
    2. 在构造器中,同时赋于新的cookie值
    3. 调用response.addCookie(cookie)
1. 先创建一个要修改的同名的cookie对象
        2. 在构造器中,同时赋于新的cookie值
     		 Cookie cookie = new Cookie("key2", "dddd");
        3. 调用response.addCookie(cookie)
        	resp.addCookie(cookie);
       		try {
           		 resp.getWriter().write("修改cookie成功");
      		} catch (IOException e) {
           e.printStackTrace();
       	 }

​ 方案二:

  1. 先查找到需要修改的Cookie对象
  2. 调用setValue()方法赋于新的Cookie值。
  3. 调用setValue()方法赋于新的Cookie值。
 //方式二:
        //        1、先查找到需要修改的Cookie对象
        Cookie cookie = CookieUtils.findCookie("key2", req.getCookies());
        if (cookie != null) {
//            2、调用setValue()方法赋于新的Cookie值。
            cookie.setValue("newValue2");
//        3、调用response.addCookie()通知客户端保存修改
            resp.addCookie(cookie);
        }
        resp.getWriter().write("key1的Cookie已经修改好");
    }
  • Cookie的生命控制

    生命控制指的是cookie什么时候被销毁

    方法: setMaxAge()

    ​ 正数: 表示在指定的秒数后过期

    ​ 负数:表示浏览器一关闭,就会被删除(默认是-1)

    ​ 0:表示马上删除cookie

 /**
     * 设置存活1个小时的Cooie
     * @param req
     * @param resp
     * @throws ServletException
     * @throws IOException
     */
    protected void life3600(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {

        Cookie cookie = new Cookie("life3600", "life3600");
        cookie.setMaxAge(60 * 60); // 设置Cookie一小时之后被删除。无效
        resp.addCookie(cookie);
        resp.getWriter().write("已经创建了一个存活一小时的Cookie");

    }

    /**
     * 马上删除一个Cookie
     * @param req
     * @param resp
     * @throws ServletException
     * @throws IOException
     */
    protected void deleteNow(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        // 先找到你要删除的Cookie对象
        Cookie cookie = CookieUtils.findCookie("key4", req.getCookies());
        if (cookie != null) {
            // 调用setMaxAge(0);
            cookie.setMaxAge(0); // 表示马上删除,都不需要等待浏览器关闭
            // 调用response.addCookie(cookie);
            resp.addCookie(cookie);

            resp.getWriter().write("key4的Cookie已经被删除");
        }

    }

    /**
     * 默认的会话级别的Cookie
     * @param req
     * @param resp
     * @throws ServletException
     * @throws IOException
     */
    protected void defaultLife(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        Cookie cookie = new Cookie("defalutLife","defaultLife");
        cookie.setMaxAge(-1);//设置存活时间
        resp.addCookie(cookie);
    }

    protected void getCookie(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {

        Cookie[] cookies = req.getCookies();



        for (Cookie cookie : cookies) {
            // getName方法返回Cookie的key(名)
            // getValue方法返回Cookie的value值
            resp.getWriter().write("Cookie[" + cookie.getName() + "=" + cookie.getValue() + "] <br/>");
        }


        Cookie iWantCookie = CookieUtils.findCookie("key1", cookies);

//        for (Cookie cookie : cookies) {
//            if ("key2".equals(cookie.getName())) {
//                iWantCookie = cookie;
//                break;
//            }
//        }
        // 如果不等于null,说明赋过值,也就是找到了需要的Cookie
        if (iWantCookie != null) {
            resp.getWriter().write("找到了需要的Cookie");
        }


    }
  • Cookie的有效Path的设置

    Path属性可以有效的过滤哪些cookie可以发送给服务器,哪些不发。

    对请求地址进行有效过滤
    在这里插入图片描述

  • Cookie实现免用户名登录
    在这里插入图片描述

 protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        String username = req.getParameter("username");
        String password = req.getParameter("password");

        if ("wzg168".equals(username) && "123456".equals(password)) {
            //登录 成功
            Cookie cookie = new Cookie("username", username);
            cookie.setMaxAge(60 * 60 * 24 * 7);//当前Cookie一周内有效
            resp.addCookie(cookie);
            System.out.println("登录 成功");
        } else {
//            登录 失败
            System.out.println("登录 失败");
        }

    }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值