Cookie

Cookie

  • 会话:一次会话中包含多次请求和响应。

    • 一次会话:浏览器第一次给服务器资源发送请求,会话建立,直到有一方断开为止
  • 功能:在一次会话范围内的多次请求间,共享数据。

  • 方式:

    1. 客户端会话技术:Cookie
    2. 服务器端会话技术:Session
  • 概念:客户端会话技术,将数据保存到客户端。

  • 快速入门:

    • 使用步骤:
      1. 创建Cookie对象,绑定数据
        • new Cookie(String name, String value)
      2. 发送Cookie对象
        • resp.addCookie(Cookie cookie)
      3. 获取Cookie,拿到数据
        • req.getCookies()
  • 实现原理

    • 基于响应体set-cookie和请求头cookie实现
  • cookie的细节

    1. 一次可不可以发送多个cookie?
      • 可以
      • 可以创建多个cookie对象,然后用addCookie发送
    2. cookie在浏览器中保存多长时间?
      • 默认情况下,浏览器关闭后,cookie数据被销毁
      • 持久化存储:setMaxAge(int seconds)
        1. 正数:将Cookie数据写到硬盘的文件中,持久化存储,数值代表cookie存活时间
        2. 负数:默认值
        3. 零:删除cookie信息
    3. cookie能不能存中文?
      • 在tomcat8之前,cookie中不能直接存储中文数据,需要将中文数据转码,一般采用URL编码
      • tomcat8之后可以存储
    4. cookie获取范围是多大?
      1. 假设在一个tomcat服务器中,部署了多个web项目,那么在这些web项目中,cookie能不能共享?
        • 默认情况下,cookie不能共享
        • setPath(String path):设置cookie的获取范围,默认情况下设置当前的虚拟目录
        • 如果要共享,则可以将path设置为”/“
      2. 不同的tomcat服务器获取cookie?
        • setDomain(String path):如果设置一级域名相同,那么多个服务器之间cookie可以共享
        • 如:setDomain(“.baidu.com”),那么tieba.baidu.com和news.baidu.com可以共享cookie
  • cookie的特点和作用

    1. cookie存储数据在客户端浏览器,不太安全
    2. 浏览器对于单个cookie有限制(4kb左右),以及对同一个域名下的总cookie数量也有限制 (20个左右)
    • 作用:
      1. cookie一般用于存储少量的不太敏感的数据
      2. 在不登录的情况下,完成服务器对客户端的身份识别
  • 版权声明: 本博客所有文章除特别声明外,均采用 Apache License 2.0 许可协议。转载请注明出处!

请我喝杯咖啡吧~

支付宝
微信