session使用
1.服务器端会话跟踪技术:将数据保存在服务器端
底层基于cookie实现封装的
2.常用的API:
2.1void session.setAttribute(k,v) session存入值 key=name,value ‘yushengjun’
/* * Copyright (c) 2020, 2023,All rights reserved. * */package cn.sessionTest;import jakarta.servlet.ServletException;import jakarta.servlet.annotation.WebServlet;import jakarta.servlet.http.*;import java.io.IOException;import java.io.PrintWriter;/** * Project: scl-cookie - GetSessionA
* Powered by scl On 2023-09-04 20:08:20
* 描述:
* * @author 孙臣龙 [1846080280@qq.com] * @version 1.0 * @since 17 */@WebServlet("/getSessionA")public class GetSessionA extends HttpServlet {@Overrideprotected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {HttpSession session = req.getSession();System.out.println(session.getId());session.setAttribute("name","scl");Cookie c = new Cookie("JSESSIONID",session.getId());c.setMaxAge(60*60); //1个小时有效期resp.addCookie(c);PrintWriter writer = resp.getWriter();writer.println("ok");writer.close();}}
2.2Object session.getAttribute(k) 获取到session中的值
/* * Copyright (c) 2020, 2023,All rights reserved. * */package cn.sessionTest;import jakarta.servlet.ServletException;import jakarta.servlet.annotation.WebServlet;import jakarta.servlet.http.*;import java.io.IOException;import java.io.PrintWriter;/** * Project: scl-cookie - GetSessionB
* Powered by scl On 2023-09-04 20:11:25
* 描述:
* * @author 孙臣龙 [1846080280@qq.com] * @version 1.0 * @since 17 */@WebServlet("/getSessionB")public class GetSessionB extends HttpServlet {@Overrideprotected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {HttpSession session = req.getSession();System.out.println(session.getId());String name =(String) session.getAttribute("name");PrintWriter writer = resp.getWriter();writer.println("sessionValue:"+name);writer.close();}}
2.3void removeAttribute(k) 删除我们的session
session原理
1.当我们客户端发送请求达到服务器端时创建session,会得到一个sessionid,在将该
sessionid 响应在响应头
2.客户端(浏览器)接受响应头中的sessionid ,会将该sessionid的值 存放在浏览器中。
session本质上就是基于cookie实现封装的。
3.使用同一个浏览器发送请求时,访问通一个服务器端,会在请求头中设定该sessionid 的值,服务器端就会从请求头中获取到该sessionid 查找对应session。
session 数据存放在服务器端 cookie将数据存放在本地。
session细节
1.当客户端关闭后,服务器不关闭的话,获取到的session是否是同一个。因为客户端关闭后,cookie对象被销毁,客户端请求服务器会创建新的session。如果需要相同,可以设置cookie的最大存活时间,让cookie持久化保存两次获取Session是否为同一个
2.在默认情况下,不是同一个。如果需要两个Session相同,则可以创建一个Cookie对象,key为:JSESSIONID,设置一下最大存活时间,让Cookie持久化保存Session的ID,就可以实现客户端关闭,两次获取Session就是同一个。
Cookie c = new Cookie("JSESSIONID",session.getId());c.setMaxAge(60*60); //1个小时有效期response.addCookie(c);
session与cookie区别
1.session用于存储一次会话的多次请求的数据,存在服务器端;
2.session可以存储任意类型,任意大小的数据。
session与Cookie的区别:
1.session存储数据在服务器端,Cookie在客户端;
2.session没有数据大小限制,Cookie有数据大小限制;
3.session数据安全,Cookie相对于不安全。