每个客户端与服务器交互时生成会话的sessionID是唯一,同个客户端在访问不同的域名:主域名、子域名、跨站点域名或跨服务器域名,会有不同的sessionID,有些应用程序会在session存放用户的状态和信息,同个应用程序的客户端需访问不同的服务端项目,为了使用户在登入后能够在规定时间内保持登入状态,需要进行session共享,多个的项目之间可以使用同个session;
简而言之:不同的服务器之间使用同个用户的session数据
服务端程序调用HttpServletRequest的getSession()时,创建java对象session,,服务器会为该Session生成唯一的Session id;通过对象的相关api可以存放数据,响应客户端(携带sessionId),客户端再次请求时会携带id,服务器接受到请求之后就会依据Session id找到相应的Session;
在服务端session存放在内存中,客户端的Cookie保存sessionID;
1)超时 2)程序调用HttpSession.invalidate() 3)程序关闭;
id="redisHttpSessionConfiguration" class="org.springframework.session.data.redis.config.annotation.web.http.RedisHttpSessionConfiguration">
demo
程序中:
request.getSession().setAttribute("member", member);//会员信息;