一、Httpssiton(服务端)会话技术
1.服务器会为每个用户,创建一个独立的Httpsession
2.原理:当用户第一次访问servlet时,服务器端会给用户创建一个独立的session并且生成一个sessionid,这个sessionid在相应的浏览器的时候,会被装进cookie中,从而被保存到浏览器中,当用户再一次访问servlet的时候,请求中会携带着cookie中的sessionid去访问,服务器会根据这个sessionid,去查看是否有对应的session对象,有就拿出来使用,没有就创建一个(相当于用户第一次访问)
3.三个域的范围:
Context域》Session域》Request域
Session域,只要会话不结束,就会存在,但是Session有默认的存活时间,30分钟
二、Session钝化
1.钝化
服务器停止时,如果你的session中保存了对象,并且该对象是实现了序列化接口Serializable系统会把你保存的session序列化到服务器的work文件夹你的工程下一个文件
2.活化
当你重新启动服务器,系统会重新把钝化下来的那个文件加载回session中
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 + " " + session.getId());
}
public void doPost(HttpServletRequest request,
HttpServletResponse response) throws ServletException, IOException {
doGet(request, response);
}
}