HttpSession-服务端会话技术
HttpSession 域对象 可以存东西
服务器会为每一个用户创建一个独立的HttpSession
HttpSessionn 原理
当Servlet第一次访问Servlet的时候 服务器端会给该用户创建一个独立的Session
并且生成一个SessionID,这个Session在响应浏览器的时候 会被装进cookie中
从而被保存在浏览器中 当用户下一次再一次访问Servlet的时候,请求中会携带着cookie中的SessionID去访问
服务器会根据这个sessionID去查看是否有Session对象 有就拿出来使用
没有 就创建一个Session(相当于第一次访问)
域的范围
Context域 > Session域 > Request域
Session域 只要会话不结束,就会存在 但是Session有默认的存活时间 30分钟
简单实现
在访问网址中?后面加上一条信息,在demo01中通过请求捕获这条信息,再通过request获取session域,将这条信息保存到
session域中,由于session域存在的时间较长,只要会话不关闭,session便可存在(30分钟),且一个用户对应一个session
此时再用demo02获取这条session,将session中username里的值取出来,输出到网页
public class Demo01 extends HttpServlet {
public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
response.setContentType("text/html;charset=UTF-8");
request.setCharacterEncoding("UTF-8");
String username = request.getParameter("username");
HttpSession session = request.getSession();
session.setAttribute("username", username);
}
public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
doGet(request, response);
}
}
public class Demo02 extends HttpServlet {
public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
response.setContentType("text/html;charset=UTF-8");
request.setCharacterEncoding("UTF-8");
HttpSession session = request.getSession();
String username = (String)session.getAttribute("username");
response.getWriter().write(username);
}
public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
doGet(request, response);
}
}
<servlet>
<servlet-name>user</servlet-name>
<servlet-class>com.lanou3g.Demo01</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>user</servlet-name>
<url-pattern>/user</url-pattern>
</servlet-mapping>
<servlet>
<servlet-name>demo02</servlet-name>
<servlet-class>com.lanou3g.Demo02</servlet-class>
</