一、Session介绍
- Session对象是一个域对象,在服务器为该客户端第一次调用getSesson()方法时创建,在浏览器关闭时销毁。
- 将数据保存在服务器。
- 与Cookie相比:数据存储在服务器更安全,在Session存储数据没有大小限制。
- 实现原理:基于有效时间为0且有效路径为当前项目的上下文路径的Cookie实现,也就是默认级别的Cookie。Servlet在第一次获取Session时,会创建一个Session对象,然后利用默认级别的Cookie返回一个Session标识符(JSESSIONID)给客户端,客户端之后的请求都会携带该Session标识符,利用该标识符找到对应的Session对象。由于是默认级别的Cookie,当关闭浏览器后,Session标识符也就消失了。
- 项目测试
(1)编写MyServlet继承HttpServlet类
public class MyServlet extends HttpServlet {
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
HttpSession session = req.getSession();
String username = (String) session.getAttribute("username");
String msg = "";
if (username == null){
session.setAttribute("username", "root");
msg = "无";
}else {
msg = username;
}
resp.setContentType("text/html;charset=UTF-8");
PrintWriter writer = resp.getWriter();
writer.print(msg);
}
}
(2)编写web.xml文件,配置Servlet
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd"
version="4.0">
<servlet>
<servlet-name>MyServlet</servlet-name>
<servlet-class>com.wsh.servlet.MyServlet</servlet-class>
<!--load-on-startup的值大于等于0时,Servlet在Tomcat启动时初始化-->
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>MyServlet</servlet-name>
<url-pattern>/test01</url-pattern>
</servlet-mapping>
</web-app>
(3)配置Tomcat中的项目上下文路径
(4)运行
两次访问/test01/test01
注:可以用setMaxInactiveInterval()方法给Session设置有效时间。