一、Cookie
    Cookie的数据是由客户端来保存和携带的,所以称之为客户端技术。
  1、属性:
    name:名称不能唯一确定一个Cookie。路径可能不同。
    value:不能存中文。
    path:默认值是写Cookie的那个程序的访问路径
      比如:http://localhost:8080/day10_00_cookie/servlet/ck1写的Cookie
        path就是:/day10_00_cookie/servlet 看当前创建cookie的资源(servlet)文件路径
          客户端在访问服务器另外资源时,根据访问的路径来决定是否带着Cookie到服务器
          当前访问的路径如果是以cookie的path开头的路径,浏览器就带。否则不带。

    maxAge:cookie的缓存时间。默认是-1(默认存在浏览器的内存中)。单位是秒。
      负数:cookie的数据存在浏览器缓存中
      0:删除。路径要保持一致,否则可能删错人。
      正数:缓存(持久化到磁盘上)的时间

二、HttpSession
  1、HttpSession定义
    > 它也是一个域对象: session servletContext request
    > 同一个会话下,可以使一个应用的多个资源共享数据
    > cookie客户端技术,只能存字符串。HttpSession服务器端的技术,它可以存对象。

  2、常用方法
    把数据保存在HttpSession对象中,该对象也是一个域对象。
    void setAttribute(String name,Object value);
    Object getAttribute(String name);
    void removeAttribute(String name);
    HttpSession.getId():

      setMaxInactiveInterval(int interval) 设置session的存活时间
      invalidate() 使此会话无效

  3、getSession():内部执行原理
      HttpSession request.getSession():内部执行原理
        1、获取名称为JSESSIONID的cookie的值。
        2、没有这样的cookie,创建一个新的HttpSession对象,分配一个唯一的SessionID,
          并且向客户端写了一个名字为JSESSIONID=sessionID的cookie
        3、有这样的Cookie,获取cookie的值(即HttpSession对象的值),

          从服务器的内存中根据ID找那个HttpSession对象:
          找到了:取出继续为你服务。
        找不到:从2开始。

    HttpSession request.getSession(boolean create):
      参数:
        true:和getSession()功能一样。
        false:根据客户端JSESSIONID的cookie的值,找对应的HttpSession对象,找不到返回null(不会创建新的,只是查询)。

  4、客户端禁用Cookie后的会话数据保存问题
    客户端禁用cookie:浏览器永远不会向服务器发送cookie的请求消息头

    解决方案:
      方案一:在主页上给出提示:请不要禁用您的cookie
      方案二:URL重写。必须对网站的所有地址都重写。

    http://url--->http://url;JSESSIONID=111

    response.encodeURL(String url);
      看浏览器有没有发送cookie请求消息头,没有就重写URL,有就不重写。

    request.getSession();必须写

coockie 和 session的更多相关文章

  1. session实现购物车

    为实现简单的购物功能(购物车添加.账户查看.购物车商品删除.实时的购物商品数量及价格的计算显示.购物车商品数量可手动输入等),用session实现了一简单的以php语言为基础.连接MySQL数据库的购 ...

  2. Asp.net Core中使用Session

    前言 2017年就这么悄无声息的开始了,2017年对我来说又是特别重要的一年. 元旦放假在家写了个Asp.net Core验证码登录, 做demo的过程中遇到两个小问题,第一是在Asp.net Cor ...

  3. 懒加载session 无法打开 no session or session was closed 解决办法(完美解决)

           首先说明一下,hibernate的延迟加载特性(lazy).所谓的延迟加载就是当真正需要查询数据时才执行数据加载操作.因为hibernate当中支持实体对象,外键会与实体对象关联起来.如 ...

  4. 探索ASP.NET MVC5系列之~~~6.Session篇(进程外Session)

    其实任何资料里面的任何知识点都无所谓,都是不重要的,重要的是学习方法,自行摸索的过程(不妥之处欢迎指正) 汇总:http://www.cnblogs.com/dunitian/p/4822808.ht ...

  5. Nhibernate的Session管理

    参考:http://www.cnblogs.com/renrenqq/archive/2006/08/04/467688.html 但这个方法还不能解决Session缓存问题,由于创建Session需 ...

  6. nginx+iis+redis+Task.MainForm构建分布式架构 之 (redis存储分布式共享的session及共享session运作流程)

    本次要分享的是利用windows+nginx+iis+redis+Task.MainForm组建分布式架构,上一篇分享文章制作是在windows上使用的nginx,一般正式发布的时候是在linux来配 ...

  7. zookeeper源码分析之六session机制

    zookeeper中session意味着一个物理连接,客户端连接服务器成功之后,会发送一个连接型请求,此时就会有session 产生. session由sessionTracker产生的,sessio ...

  8. [转载]Cookie/Session的机制与安全

    Cookie和Session是为了在无状态的HTTP协议之上维护会话状态,使得服务器可以知道当前是和哪个客户在打交道.本文来详细讨论Cookie和Session的实现机制,以及其中涉及的安全问题. 因 ...

  9. 修改session垃圾回收几率

    <?php //修改session垃圾回收几率 ini_set('session.gc_probability','1'); ini_set('session.gc_divisor','2'); ...

随机推荐

  1. 30行Python代码实现人脸检测

    参考OpenCV自带的例子,30行Python代码实现人脸检测,不得不说,Python这个语言的优势太明显了,几乎把所有复杂的细节都屏蔽了,虽然效率较差,不过在调用OpenCV的模块时,因为模块都是C ...

  2. python标准异常

    什么是异常? 异常即是一个事件,该事件会在程序执行过程中发生,影响了程序的正常执行.一般情况下,在Python无法正常处理程序时就会发生一个异常.异常是Python对象,表示一个错误.当Python脚 ...

  3. jquery的show()和hide()方法

    显示和隐藏元素的方法 相当于CSS中的display属性 show()方法,相当于display:block hide()方法,相当于display:none

  4. Missing artifact com.oracle:ojdbc6:jar:11.2.0.3 Maven中不能引入ojdbc解决方法,错误

    今天从服务器检出Maven项目的时候,遇到了一个问题,就是在pom.xml中引入ojdbc的jar包的时候出错了,提示是Missing artifact com.oracle:ojdbc6:jar:1 ...

  5. ORACLE 增加两列字段

    declare v_cnt number; V_SQL VARCHAR2 (500) := '';begin select count(*) into v_cnt from dual where ex ...

  6. 查询的model里面 一般都要有一个要返回的model做属性 ;查询前要传入得参数,查询后返回的参数 都要集合在一个model中

    查询的model里面 一般都要有一个要返回的model做属性

  7. luogu P1353 【[USACO08JAN]跑步Running】

    USACO!!! 唉!无一例外又是母牛(终于知道美国的牧场养什么了) 今天的主人公是一个叫贝茜的公主病母牛(好洋气) 可是她叫什么和我们理解题好像没有什么关系 通过读题我们可以发现她有三个傲娇的地方 ...

  8. 序列化模块组 pickle,json , xml , shelve , configparser

    序列化是什么? 序列化指的是将内存中的数据结构转化为一种中间格式 并存储到硬盘上. 反序列化是什么? 将硬盘上存储的中间格式数据再还原为内存中的数据结构. 为什么要有序列化? 是为了将数据持久存储 较 ...

  9. robotframework测试用例加入注释

    *** Variables ***${HOST} 192.168.132.135${USER} username*** Test Cases ***Simple [Documentation] Sim ...

  10. 基于FPGA的UART协议实现(通过线性序列机)

    //////////////////2018/10/15 更新源代码: 实现uart这东西其实早就写了,不过不太完善,对于一个完美主义者来说,必须解决掉它. 1.什么是UART?        通用异 ...