【web后端(九)】jsp、servlet_会话管理_session
2023-09-11 14:20:37 时间
session:
session是服务器端的一个集合,可以存储任何东西。session最重要的特性,就是可以识别用户。
例如,我们去电影院看电影。工作人员是凭借客户手里的票来识别客户的。但是,对于工作人员来说,他们并不知道客户的身份信息。
一般情况下,session是和cookie结合起来去存储东西的。也就是说,如果cookie不被允许存到客户端,session就用不了。
红框里的信息就相当于电影院给顾客发的票:
这张票是一个临时cookie,而它的值就叫做sessionID。
第一次请求session对象时:第一次请求session对象时,客户端是没有session的,需要创建一个session。且这个session可以一直用到它的存储时间限制,才会消失。 代码中的前两种取对象方式并不能取到数据,需要用后两种。
特殊情况:1、session在客户端关闭页面后就会被消除。2、当一个session没人用的时候,也会客户端被关闭
过期后:而大当我们的session过期的时候,服务器在根据地质找不到的时候,就会发送一个“当前页面已过期,请重新提交。”的提示。
Session2Servlet(结算页面)
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
import java.io.IOException;
@WebServlet(name = "Session3Servlet",urlPatterns = "/session3")
public class Session2Servlet extends HttpServlet {
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
HttpSession session = request.getSession();//取出session
response.getWriter().println(request.getAttribute("goods1"));
response.getWriter().println(request.getAttribute("goods2"));
response.getWriter().println(session.getAttribute("goods1"));
response.getWriter().println(session.getAttribute("goods2"));
}
}
SessionServlet
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
import java.io.IOException;
@WebServlet(name = "SessionServlet",urlPatterns = "/session1")
public class SessionServlet extends HttpServlet {
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
}
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
HttpSession session = request.getSession();//取出session
//设置session过期时间
session.setMaxInactiveInterval(20*60);
// session.getId();
//销毁session的方法
// session.invalidate();
//获得session的创建时间
session.getCreationTime();
//获得session最后一次被使用的时间
session.getLastAccessedTime();
session.setAttribute("goods1","Scoat");
request.setAttribute("goods1","Scoat");
}
}
Session1Servlet
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
import java.io.IOException;
@WebServlet(name = "Session1Servlet",urlPatterns = "/session2")
public class Session1Servlet extends HttpServlet {
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
HttpSession session = request.getSession();//取出session
session.setAttribute("goods2","Computer");
request.setAttribute("goods2","Computer");
}
}
相关文章
- JSP页面之间传参
- 【JAVA】TomCat服务器安装与MyEclipse新建Jsp-Web项目步骤!(一步步截图示例)
- 16JavaWeb基础 - JSP的三大指令
- JSP中脚本、声明和表达式的本质区别
- 基于Java(jsp+servlet)+Mysql实现的(Web)宿舍管理系统【100010103】
- 基于Java(JSP)实现(Web)教务管理信息系统【100010166】
- 基于Java(Jsp+Sevlet)+MySql 实现的(Web)成绩管理系统【100010041】
- CentOS7 nginx+tomcat实现代理访问java web项目让项目支持jsp和php
- SpringMVC访问WEB-INF下的jsp的方法
- 在jsp页面中定义全局变量,供其他页面引用
- 【web后端(十八)】jsp、servlet_内置标签——UseBean
- 【web后端(十四)】jsp、servlet_监听器
- 【web后端(十三)】jsp、servlet_生命周期、过滤器
- 【web后端(十二)】jsp、servlet_servlet初始化参数、servelt上下文参数
- 【web后端(十一)】jsp、servlet_会话管理_servletContext应用示例
- 【web后端(四)】jsp、servlet_请求转发、请求派发
- 【web后端(一)】jsp、servlet_查询字符串
- jsp中利用checkbox进行批量删除