美文网首页程序员
会话管理(session)

会话管理(session)

作者: 全满 | 来源:发表于2018-04-25 13:35 被阅读0次

    会话技术分类

    • cookie技术

    会话数据保存在浏览器客户端

    • session技术

    会话数据保存在服务端

    coolie技术

    • 技术核心

    cookie类(来自servlet):用于存储会话数据
    1.构造cookie对象:
    Cookie(java.lang.String name ,java.lang.String value)
    2.设置Cookie

    void setPath(java.lang.String url)设置Cookie的有效访问路径
    

    cookie.setPath(/绝对路径);

    void setMaxAge(int expiry)设置Cooike的有效时间
    

    正整数:表示cookie数据保存浏览器的缓存目录(硬盘中),数值表示保存的时间
    负整数:表示cookie数据保存浏览器的内存中,浏览器关闭cookie就丢失
    零:表示删除同名的cookie数据

    void setValue(java.lang.String newValue)设置Cookie的值
    

    3.发送Cookie到浏览器端保存
    void response.addCookie(Cookie cookie);发送Cookie
    4.服务器接受Cookie
    Cookie request.getCookies();接受Cookie

    • 小节

    cookie可以保存数据,但是cookie有条件限制,比如发送的内容只能是非中文的数据

    sesion技术核心

    HttpSession类:用于保存会话数据

    • 创建或者得到session对象
      HttpSession()
      HttpSesion(boolean create)
    • 设置session对象
      void setmaxInactiveInterval(int interval):设置session有效时间
      void invalidate():销毁session
      java.lang.String getId():得到session的编号
    • 保存会话的数据到session对象
      void setAttribute(java.lang.String , java.lang.Object value):保存数据
      java.lang.Object getAttribute(java.lang.String name):获取数据
      void removeAttribute(java.lang.String name):清除数据

    session原理

    问题:服务器能够识别不同的浏览者
    前提:从那个session域对象保存数据,就必须从哪个域对象取出

    • 总结:
      代码解读:HttpSeeesion session = request.getSession();
      • 创建session对象,给session对象分配一个唯一的ID,叫JSESSIONID
      • 把JSESSIONID作为Cookie的值发送给浏览器保存
      • 第二次访问的时候,浏览器带着JSESSSIONID的cookie访问服务器
      • 服务器得到JSESSIONID,在服务器的内存中搜索是否存放对应的编号的session对象
      • 如果找到对应编号的session对象,直接返回该对象
      • 如果找不到对应的编号session对象,创建新的session对象,继续走1的流程
        结论:通过JSESSION的cookie值在服务器找session对象

    session细节

    • java.lang.String getId():得到session的编号
    • 两个getSession方法

    getSesstion(true)/getSession(): 创建或得到session对象。没有匹配的session编号,自动创建新的session对象
    getSession(false):得到session对象。没有匹配的session编号,返回null

    • void setMaxInactivelnterval(int interval):设置session的有效时间

    session对象的销毁时间:

    • 默认情况30分钟服务器自动回收
    • 修改回收的时间(过期时间)单位:秒

    修改回收的时间
    session.setMaxInactiveInterval(20);

    • 全局修改session有效时间

    < !--修改session的有效时间:分钟-->

    <session-config>
    <session-timeout>1</session-timeout>
    </session-config>
    
    • 手动去销毁session的对象

    void invalidate() 手动销毁session对象

    • 如何避免浏览器的JSEEIONID的cookie随着浏览器关闭而丢失的问题
    /**
    *手动发送一个硬盘保存的cookie给浏览器
    */
    Cookie c = new Cookie("JCOOKIEID",session.getId());
    c.setMaxAge(60*60);  //保存一小时
    response.addCookie(c);
    

    总结

    • 会话管理:浏览器和服务器会话过程中的产生的会话数据管理
    • Cookie技术:new Cookie ("name","value")
      response.addCookie(cookie);
      request.getCookies()
    • Session 技术
      request.getSession();
      setAttribute("name","会话数据");
      getAttribute("会话数据");

    相关文章

      网友评论

        本文标题:会话管理(session)

        本文链接:https://www.haomeiwen.com/subject/zwhkqftx.html