Session的工作机制

  • 用户第一次请求服务器时,服务器端会生成一个sessionid
  • 服务器端将生成的sessionid返回给客户端,通过set-cookie
  • 客户端收到sessionid会将它保存在cookie中,当客户端再次访问服务端时会带上这个sessionid
  • 当服务端再次接收到来自客户端的请求时,会先去检查是否存在sessionid,不存在就新建一个sessionid重复1,2的流程,如果存在就去遍历服务端的session文件,找到与这个sessionid相对应的文件,文件中的键值便是sessionid,值为当前用户的一些信息
  • 此后的请求都会交换这个 Session ID,进行有状态的会话。


  • 服务器端没调用request.getSession()方法:什么都不会发生
  • 服务器端调用了request.getSession()方法
  • 服务器端检查当前请求中是否携带了JSESSIONID的Cookie
  • 有:根据JSESSIONID在服务器端查找对应的HttpSession对象
  • 能找到:将找到的HttpSession对象作为request.getSession()方法的返回值返回
  • 找不到:服务器端新建一个HttpSession对象作为request.getSession()方法的返回值返回
  • 无:服务器端新建一个HttpSession对象作为request.getSession()方法的返回值返回


1.调用request对象的方法尝试获取HttpSession对象 2.调用HttpSession对象的isNew()方法 3.打印HttpSession对象是否为新对象 4.调用HttpSession对象的getId()方法 5.打印JSESSIONID的值

// 1.调用request对象的方法尝试获取HttpSession对象
HttpSession session = request.getSession();

// 2.调用HttpSession对象的isNew()方法
boolean wetherNew = session.isNew();

// 3.打印HttpSession对象是否为新对象
System.out.println("wetherNew = " + (wetherNew?"HttpSession对象是新的":"HttpSession对象是旧的"));

// 4.调用HttpSession对象的getId()方法
String id = session.getId();

// 5.打印JSESSIONID的值
System.out.println("JSESSIONID = " + id);

session.invalidate();