Sesión (énfasis)
Qué es Session:
-
El servidor creará un objeto de sesión para cada usuario (navegador)
-
Una sesión ocupa un navegador, siempre que el navegador no esté cerrado, la sesión existirá
-
Una vez que el usuario inicia sesión, se puede acceder a todo el sitio web. -> Guardar información de usuario; guardar información de carrito de compras ...
La diferencia entre sesión y cookie:
- Cookie es para escribir los datos del usuario en el navegador del usuario, y el navegador los guarda (puede guardar varios)
- La sesión escribe los datos del usuario en la sesión exclusiva del usuario y los guarda en el lado del servidor (guarda información importante para reducir el desperdicio de recursos del servidor)
- El objeto de sesión es creado por el servidor
escenas a utilizar:
- Guardar la información de un usuario que inició sesión
- Información del carrito de compras
- Datos que se utilizan frecuentemente en todo el sitio web, los guardamos en la Sesión
Usar sesión:
public class SessionDemo01 extends HttpServlet {
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
//解决乱码问题
req.setCharacterEncoding("UTF-8");
resp.setCharacterEncoding("UTF-8");
resp.setContentType("text/html;charset=utf-8");
//得到Session
HttpSession session = req.getSession();
//给Session中存东西
session.setAttribute("name",new Person("家明","1"));
//获取Session的ID
String sessionId = session.getId();
//判断Session是不是新创建
if (session.isNew()){
resp.getWriter().write("Session创建成功,ID:"+sessionId);
}else {
resp.getWriter().write("Session已经在服务器中存在了,ID:"+sessionId);
}
//Session创建的时候做了什么事情;
// Cookie cookie = new Cookie("JSESSIONID",sessionId);
// resp.addCookie(cookie);
}
@Override
protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
doGet(req, resp);
}
}
//得到Session
HttpSession session = req.getSession();
Person person = (Person) session.getAttribute("name");
System.out.println(person.toString());
HttpSession session = req.getSession();
session.removeAttribute("name");
//手动注销Session
session.invalidate();
La sesión caduca automáticamente (configurada en web.xml):
<!--设置Session默认的失效时间-->
<session-config>
<!--15分钟后Session自动失效,以分钟为单位-->
<session-timeout>15</session-timeout>
</session-config>