1. 概念
      客户端会话技术,将数据保存到客户端,以后每次请求都携带Cookie数据进行访问。
    2. Cookie的工作流程
      1. 服务端提供了两个Servlet,分别是ServletA和ServletB
      2. 浏览器发送HTTP请求1给服务端,服务端ServletA接收请求并进行业务处理
      3. 服务端ServletA在处理的过程中可以创建一个Cookie对象并将name=zs的数据存入Cookie
      4. 服务端ServletA在响应数据的时候,会把Cookie对象响应给浏览器
      5. 浏览器接收到响应数据,会把Cookie对象中的数据存储在浏览器内存中,此时浏览器和服务端就建立了一次会话
      6. 在同一次会话中浏览器再次发送HTTP请求2给服务端ServletB,浏览器会携带Cookie对象中的所有数据
      7. ServletB接收到请求和数据后,就可以获取到存储在Cookie对象中的数据,这样同一个会话中的多次请求之间就实现了数据共享
    3. Cookie的基本使用
      3.1 发送Cookie
      • 创建Cookie对象,并设置数据
        1. Cookie cookie = new Cookie("key","value");
    • 发送Cookie到客户端:使用response对象
      response.addCookie(cookie);
      
        3.2 **获取Cookie**
    
            获取客户端携带的所有Cookie,使用request对象
    
    Cookie[] cookies = request.getCookies();
    
            遍历数组,获取每一个Cookie对象:for
    
            使用Cookie对象方法获取数据
    
    cookie.getName();
    cookie.getValue();
    
    1. Cookie的存活时间
      Cookie其实已经为我们提供好了对应的API来完成这件事,这个API就是setMaxAge,
      • 设置Cookie存活时间
         setMaxAge(int seconds)
         //发送Cookie
         //1. 创建Cookie对象
         Cookie cookie = new Cookie("username","zs");
         //设置存活时间   ,1周 7天
         cookie.setMaxAge(60*60*24*7); //易阅读,需程序计算
         //cookie.setMaxAge(604800); //不易阅读(可以使用注解弥补),程序少进行一次计算
         //2. 发送Cookie,response
         response.addCookie(cookie);
        
    1. cookie中存储特殊字符问题

      cookie中不能直接存储特殊字符:空格 分号等,如果存储必须先编码在存储,能够向cookie中存储特殊字        符。
      
             /*
                向cookie中存储特殊字符问题演示
             */
            //1.创建Cookie类的对象
            // Cookie cookie = new Cookie("msg", "12 34");报错
            String str = "12 34";
            //编码
            String encode = URLEncoder.encode(str, "utf-8");
            Cookie cookie = new Cookie("msg", encode);
            //2.将cookie存储到浏览器端
            response.addCookie(cookie);