Session的作用:记录一系列状态
以登录为例子,在登录请求发送到服务端,然后后台进行判断,response给用户登录成功的信息后,我们需要返回用户专属于自己的参数,那么需要对服务器进行第二次请求,但是第二次请求数据并不保留,所以我们需要使用 Seesion 来是实现不同请求的数据共享;
换一个说法就是,用户进行多次请求的时候,保证是同一个请求对象,拿到同一个对象
客户端请求的时候,服务器会开辟一个Session内存保存在服务器,然后通过Cookie存储在浏览器中,确保是同一个用户发起的多次请求(依赖于Cookie)
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
import java.io.IOException;
public class Sessionts extends HttpServlet {
@Override
protected void service(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
req.setCharacterEncoding("UTF-8");
resp.setCharacterEncoding("UTF-8");
resp.setContentType("text/html;charset=UTF-8");
String name = req.getParameter("name");
//创建Seesion对象
HttpSession HS = req.getSession();//让Seesion获取对象
//使用Seesion获取用户ID,并且依赖Cookie保存在浏览器
System.out.println(HS.getId());
}
}
这是用户的第一个请求
我们编写第二个对象并且同样获取用户ID
public class ssts2 extends HttpServlet {
@Override
protected void service(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
req.setCharacterEncoding("UTF-8");
resp.setCharacterEncoding("UTF-8");
resp.setContentType("text/html;charset=UTF-8");
HttpSession HS = req.getSession();
System.out.println(HS.getId());
}
}
如果输出,会同样输出第一个请求的ID
如果一个会话(打开一个浏览器到关闭),被重新开启,那么存储的seesion就会失效
我们也可以通过设置Session的存在时间
HS.setMaxInactiveInterval(5);//括号内输入的是秒
这个语句来设置SeesionID的生命周期,注意(这里的10S不是指在10S后SessionID就被雄销毁,如果用户正在使用这个SeesionID那么就不会被销毁,10S指的是没有任何操作的10S
我们说Session使用于记录用户信息状态的,我们可以通过语句来获取信息存储在Session中
HS.setAttribute("name",name);//保存用户name在Session中
HS.getAttribute("name");//获取Session中的数据