Notas de estudio de JavaWeb 20/10/23 Sesión

Sesión (énfasis)

Qué es Session:

Inserte la descripción de la imagen aquí

  • 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>

Inserte la descripción de la imagen aquí

Supongo que te gusta

Origin blog.csdn.net/qq_44685947/article/details/109249046
Recomendado
Clasificación