JavaWeb-会话技术( Cookie 和 Sesssion )


会话技术


1. Cookie

  1. 概念:客户端会话技术,将数据保存到客户端
  2. 具体操作:
    1. 创建Cookie对象,绑定数据
      • new Cookie(String name,String value);
    2. 发送Cookie对象
      • response.addCookie(Cookie cookie);
    3. 获取Cookie,拿到数据
      • Cookie[] request.getCookies();
  3. 实现原理
    • 基于响应头set-cookie和请求头cookie实现
  4. Cookie的细节:
    1. 一次可以发送多个Cookie吗?
      • 可以发送多个Cookie,只需要在响应中多次调用addCookie()即可
    2. cookie默认在浏览器中保存多长时间?
      1. 默认情况下:当浏览器关闭后,Cookie数据被销毁
      2. 使用setMaxAge(int seconds)
        • 正数:将Cookie数据写入硬盘的文件中,可以持久化存储。需要指定Cookie的存活时间,当时间到后Cookie自动销毁。
        • 负数:默认值
        • 0:删除Cookie信息
    3. cookie是否可以存储中文数据?
      • 在tomcat8以前cookie中不能直接存储中文数据。
        • 解决方法:将中文数据进行转码-->使用URL编码
      • 在tomcat8之后,cookie支持中文数据。特殊的字符还是不支持,建议使用URL编码存储,然后使用URL编码解析

      URL编码的使用:

      1. URLEncoder.encode(String data,String charset); //编码
        str = URLEncoder.encode(str,"utf-8");
      2. URLDecoder.decode(String data,String charset); //解码
        value = URLDecoder.decode(value,"utf-8");
    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可以共享
  5. Cookie的作用和特点
    1. cookie存储数据在客户端浏览器
    2. 浏览器对于单个cookie的大小有限制(4kb)以及同一个域名下的总cookie数量也有限制(20个)
    3. cookie的作用:
      1. cookie一般用于存储少量不太敏感的数据
      2. 在不登陆的情况下,完成服务器对客户端的身份识别

2. Session

  1. 概念:服务器端会话技术,在一次会话的多次请求间共享数据,将数据保存在服务器端的对象中(HttpSession)
  2. 具体操作:
    1. 获取HttpSession对象
      • HttpSession session = request.getSession();
    2. 使用HttpSession独享
      • Object getAttribute(String name);
        • String name = (String)session.getAttribute(String name);
      • void setAttribute(String name,Object value);
        • session.setAttribute(String name,Object value);
      • void removeAttribute(String name);
        • session.removeAttribute(String name);
    3. Session的原理
      • Session的实现是依赖Cookie的
    4. Session的细节:
      1. 当客户端关闭后,服务器端不关闭,两次获取的Session是否为同一个Session?
        • 默认情况下不是同一个Session
        • 特殊情况下,可以通过创建Cookie,键为JSESSIONID,设置最大存活时间,让Cookie持久化存储
          Cookie cookie = new Cookie("JSESSIONID",session.getId());
          cookie.getMaxAge(60*60);
          response.addCookie(cookie);
          
      2. 当客户端不关闭,服务器关闭后,两次获得的Session是同一个吗?
        • 不是同一个,但是为了确保数据不丢失,tomcat自动完成了以下的工作:
          1. session的钝化:
            • 在服务器正常关闭之前,将session对象系列化到硬盘上。
          2. session的锐化:
            • 在服务器启动后,将session文件转化为内存中的session,保证数据上的正确性。
      3. session什么时候被销毁?
        1. 服务器关闭
        2. session对象调用invalidate()。
        3. session的默认失效时间为30分钟
          • 可在web.xml中进行配置的修改
          <session-config>
              <session-timeout>30</session-timeout>
          </session-config>
          
    5. Session的特点:
      1. session用于存储一次会话中多次请求的数据,存储在服务器端。
      2. session可以存储任意类型任意大小的值,Cookie只能存储String类型。
    6. Session和Cookie的区别:
      1. session将数据存储与服务器端,Cookie存储在客户端。
      2. session没有数据大小限制,Cookie有数据大小限制。
      3. session数据安全,Cookie数据相对不安全
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,717评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,501评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,311评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,417评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,500评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,538评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,557评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,310评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,759评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,065评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,233评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,909评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,548评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,172评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,420评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,103评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,098评论 2 352

推荐阅读更多精彩内容