会话技术Session_细节和特点

细节:

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

   1.默认情况下不是

把浏览器关闭后在访问 session的地址值不一样了

 

 

 如果需要相同,则可以创建Cookie,键为JSESSIONID,设置最大存活时间,让cookie持久化保存

@WebServlet("/sessionD3")
public class SessionD3 extends HttpServlet {
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        //使用Session获取数据
        //获取Session
        HttpSession session = request.getSession();
        System.out.println(session);
        //期望客户端关闭后,session也能相同
        Cookie c = new Cookie("JSESSIONID", session.getId());
        c.setMaxAge(60*60);
        response.addCookie(c);

    }

    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        this.doPost(request, response);
    }
}

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

  1.不是同一个,要确保数据不丢失

 

 

 

  >session的钝化:

    在服务器正常关闭之前,将session对象序列化到硬盘上

  >session的活化:

    在服务器启动后,将session文件转化为内存中的session对象即可。

##(tomcat服务器已经帮我们把钝化和活化的事情完成了,我们不需要考虑

idea中完成不了,它可以钝化,但是活化不了)——操作(20_会话技术_Session_细节2)

【本地硬盘操作】

 

3.session的失效时间(什么时候被销毁)。

  1.服务器关闭

  2.session对象调用invalidate()。

  3.session默认失效时间 30分钟

在D:\apache-tomcat-9.0.22\conf\web.xml下

  配置修改

     <session-config>

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

    </session-config>

session的特点

①session用于存储一次会话的多次请求的数据,存在服务器端

②session可以存储任意类型,任意大小的数据

session与cookie的区别:

  1.session存储数据在服务器端,Cookie在客户端

  2.session没有数据大小限制,Cookie有

  3.session数据安全,Cookie相对于不安全

 

 

posted @ 2022-08-14 20:18  魔光领域  阅读(32)  评论(0编辑  收藏  举报