• Session详解


    简述

      session是一种服务器端会话技术,在一次会话的多次请求间共享数据,将数据放在服务器端。

    HttpSession类入门

      HttpSession是对session数据的操作进行了一个封装,它是一个接口

    获取HttpSession对象

    HttpSession session = request.getSession() 获取HttpSession对象

    数据的共享

    Object getAttribute(String name)   根据键名获取值
    void setAttribute(String name, Object value) 设置session键值对
    void removeAttribute(String name)   根据键移除值

    session的原理

      session是依赖于cookie的,cookie是由请求头和响应头实现的。

      当第一次获取session时,没有cookie,会在内存中创建一个新的session对象,并且有一个唯一的ID,给服务器做相应的时候,会发送一个响应头,并把cookie数据中的sessionID响应给客户端

      当第二次请求的时候,cookie会携带session对象的ID,这样就确保了两次获取的session对象是同一个

    session的细节

    客户端关,服务器不关

      当客户端关闭后,服务器不关闭,两次获取session是否为同一个?

      * 默认情况下。不是。
      * 如果需要相同,则可以创建Cookie,键为JSESSIONID,设置最大存活时间,让cookie持久化保存。

    Cookie c = new Cookie("JSESSIONID",session.getId());
    c.setMaxAge(60*60);
    response.addCookie(c);

    客户端不关,服务器关

      客户端不关闭,服务器关闭后,两次获取的session是同一个吗?

      * 不是同一个,但是要确保数据不丢失。tomcat自动完成以下工作
      session的钝化:
      * 在服务器正常关闭之前,将session对象系列化到硬盘上
      session的活化:
      * 在服务器启动后,将session文件转化为内存中的session对象即可。

    session什么时候被销毁

      1. 服务器关闭
      2. session对象调用invalidate() 。
      3. session默认失效时间 30分钟
      选择性配置修改,我们可以在tomcat的web.xml找到session的配置标签

    <session-config>
      <session-timeout>30</session-timeout>
    </session-config>

    session的特点

      1. session用于存储一次会话的多次请求的数据,存在服务器端
      2. session可以存储任意类型,任意大小的数据

    与cookie的区别

      1. session存储数据在服务器端,Cookie在客户端
      2. session没有数据大小限制,Cookie有
      3. session数据安全,Cookie相对于不安全

    当cookie被禁用时session的可用性

      session是依赖于cookie来实现的,用户需要通过cookie来传递自己对应的sessionid来告诉浏览器自己的session编号来获取资源

      如果客户端禁用了cookie,那么此时session就会受到影响,服务器获取不到sessionid,session就用不了

      但此时我们可以通过其他手段告诉服务器sessionid来使用session

    手动将sessionid放在URL里传参

      我们可以把sessionid放在url中进行传递,本质上是放在请求头里面,然后服务器获取sessionid参数

      在servlet中拿到sessionid后,手动将sessionid以;jsessionid=xxx的形式放在要重定向跳转的url里,重定向终点的servlet就会拿到sessionid  

    使用函数帮我们封装URL信息

      对于servlet输出到页面的url,我们使用response.encodeURL将sessionid放在url里

      对于需用重定向的url,我们使用response.encodeRedirectURL()将sessionid放在要跳转的url里

    
    
    
    
    

        

    一点一点积累,一点一点蜕变!
  • 相关阅读:
    How To Configure Server Side Transparent Application Failover [ID 460982.1]
    10g & 11g Configuration of TAF(Transparent Application Failover) and Load Balancing [ID 453293.1]
    AIX 系统介绍
    10g & 11g Configuration of TAF(Transparent Application Failover) and Load Balancing [ID 453293.1]
    Parameter DIRECT: Conventional Path Export Versus Direct Path Export [ID 155477.1]
    Linux下 数据文件 效验问题
    open_links_per_instance 和 open_links 参数说明
    Oracle 外部表
    Export/Import DataPump Parameter ACCESS_METHOD How to Enforce a Method of Loading and Unloading Data ? [ID 552424.1]
    Linux下 数据文件 效验问题
  • 原文地址:https://www.cnblogs.com/qq2210446939/p/14837656.html
Copyright © 2020-2023  润新知