Session
什么是Session:
服务器会给每一个用户(浏览器)创建一个Seesion对象;
一个Seesion独占一个浏览器,只要浏览器没有关闭,这个Session就存在;
用户登录之后,整个网站它都可以访问!–> 保存用户的信息;保存购物车的信息……
Session和cookie的区别:
Cookie是把用户的数据写给用户的浏览器,浏览器保存 (可以保存多个)
Session把用户的数据写到用户独占Session中,服务器端保存 (保存重要的信息,减少服务器资
源的浪费)
Session对象由服务创建;
使用场景:
保存一个登录用户的信息;
购物车信息;
在整个网站中经常会使用的数据,我们将它保存在Session中;
关键代码
HttpSession session = req.getSession();//获取session
session.setAttribute();//向session中存东西
session.getAttribute();//获取存在session的东西
String sessionId = session.getId();//获取session的id
session.isNew();//判断session是不是新建
session.invalidate();//手动注销session
session.setMaxInactiveInterval();//设置session过期时间
当然还可以在web.xml中设置session过期时间
<!--设置Session默认的失效时间-->
<session-config>
<!--15分钟后Session自动失效,以分钟为单位-->
<session-timeout>15</session-timeout>
</session-config>