Session是JavaWeb的一种约束是一个接口,session就是会话,是用来维护一个客户端和服务器之间进行关联的技术。每个客户端都有自己的一个session会话。【在打开浏览器打开一个网站之后,知道关闭浏览器。这期间就叫做会话】
如何创建Session和获取session:
创建session:使用方法request.getSession();
获取session:使用方法request.getSession();方法。
【第一次调用request.getSession();方法的时候是进行创建session对象,以后调用request.getSession();方法就是在获取session对象。】
既然是创建和调用都是使用一个方法,那么据需要判断获取的session对象是不是新建的使用
session.isNew()方法。【返回值true标识刚创建,flase表示之前就进行了创建】
session的生命周期控制【也就是超时控制】:
超时控制的常用方法:
SetMaxInactivelnterval(int interval) 设置Session的超时时间(以秒为单位) ,超过指定的时常,session就会被销毁。默认是在打开网站到关闭浏览器。
interval: 如果是正数的话,那么就会在超时时间后继续销毁
如果是负数的话,那么将永远不会超时。
Invalidate()方法:作用是使session立即超时。
GetMaxctiveInterval()方法:获取session的超时时间。
上述的方法只是对单一的session进行的操作,可以在web.xml文件中进行对于全部的session进行操作,示例如下:
代码示例:
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
resp.setContentType("text/html;charset=UTF-8");//解决中文乱码
HttpSession session = req.getSession();//获取session对象
session.setMaxInactiveInterval(3);//设置session 3秒后继续销毁
boolean aNew = session.isNew(); //判断session是不是新创建的
if (aNew==true){
resp.getWriter().write("新创建的session");
}else{
resp.getWriter().write("不是新创建的session");
}
}
session域对象的特点:
session域的作用范围:在一次会话中所有的Servlet及其jsp
代码示例:
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
HttpSession session = req.getSession();
session.setAttribute("uusername","sdjisdos");
}
// jsp中的内容
<head>
<title>Title</title>
</head>
<body>
<%
session.getAttribute("username");
%>
</body>
</html>
session的底层原理:
session的使用依赖与cookie