位置: IT常识 - 正文

Session详解(sessionn)

编辑:rootadmin
Session详解

推荐整理分享Session详解(sessionn),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:session.,session介绍,sessionn,session session,session实例,session的含义,session讲解,session的理解,内容如对您有帮助,希望把文章链接给更多的朋友!

👑 博主简介:    🥇 Java领域新星创作者    🥇 阿里云开发者社区专家博主、星级博主、技术博主 🤝 交流社区:BoBooY(优质编程学习笔记社区)

前言:上节我们详细讲解了Cookie,这节我们来聊一聊Session,并在最后总结一下Cookie与Session各自的特点和区别。

文章目录3、Session3.1、Session的基本使用3.1.1、概念3.1.2、Session的工作流程3.1.3、Session的基本使用3.2、Session的原理分析3.3、Session的使用细节3.3.1、Session钝化与活化3.3.2、Session的销毁4、小结3、Session3.1、Session的基本使用3.1.1、概念

Session(服务端会话跟踪技术):将数据保存到服务端。

Session是存储在服务端而Cookie是存储在客户端存储在客户端的数据容易被窃取和截获,存在很多不安全的因素存储在服务端的数据相比于客户端来说就更安全3.1.2、Session的工作流程

在服务端的AServlet获取一个Session对象,把数据存入其中在服务端的BServlet获取到相同的Session对象,从中取出数据就可以实现一次会话中多次请求之间的数据共享了3.1.3、Session的基本使用

在JavaEE中提供了HttpSession接口,来实现一次会话的多次请求之间数据共享功能。

获取Session对象,使用的是request对象HttpSession session = request.getSession();存储数据到 session 域中void setAttribute(String name, Object o)

注意:Session中可以存储的是一个Object类型的数据,也就是说Session中可以存储任意数据类型。

根据 key,获取值Object getAttribute(String name)根据 key,删除该键值对void removeAttribute(String name)《Session使用案例》创建名为SessionDemo1的Servlet类,编写创建Session的代码package com.bby;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;/** * @author BoBooY * @date 2022/11/6 15:37 */@WebServlet("/demo1")public class SessionDemo1 extends HttpServlet { @Override protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { //创建Session对象 HttpSession session = req.getSession(); //存储数据 session.setAttribute("username" , "BoBooY"); } @Override protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { this.doGet(req, resp); }}创建名为SessionDemo2的Servlet类,编写获取Session的代码package com.bby;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;/** * @author BoBooY * @date 2022/11/6 15:41 */@WebServlet("/demo2")public class SessionDemo2 extends HttpServlet { @Override protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { //获取Session对象 HttpSession session = req.getSession(); System.out.println(session); //获取数据 Object username = session.getAttribute("username"); System.out.println(username); } @Override protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { this.doGet(req, resp); }}启动项目测试

先访问http://localhost:8080/demo1 再访问http://localhost:8080/demo2

看控制台输出

3.2、Session的原理分析

Session是基于Cookie实现的

前提条件

Session要想实现一次会话多次请求之间的数据共享,就必须要保证多次请求获取Session的对象是同一个。

通过刚刚的《Session的使用案例》可以得出以下结论:

两个Servlet类中获取的Session对象是同一个把demo1和demo2请求刷新多次,控制台最终打印的结果都是同一个

如果新开一个浏览器,访问demo1或者demo2,打印在控制台的Session还是同一个对象吗?

结论:如果是不同浏览器或者重新打开浏览器后,打印的Session就不一样了。所以Session实现的也是一次会话中的多次请求之间的数据共享。

Session是如何保证在一次会话中获取的Session对象是同一个呢?

(1)demo1在第一次获取session对象的时候,session对象会有一个唯一的标识,假如是id:10

(2)demo1在session中存入其他数据并处理完成所有业务后,需要通过Tomcat服务器响应结果给浏览器

(3)Tomcat服务器发现业务处理中使用了session对象,就会把session的唯一标识id:10当做一个cookie,添加Set-Cookie:JESSIONID=10到响应头中,并响应给浏览器

(4)浏览器接收到响应结果后,会把响应头中的coookie数据存储到浏览器的内存中

(5)浏览器在同一会话中访问demo2的时候,会把cookie中的数据按照cookie: JESSIONID=10的格式添加到请求头中并发送给服务器Tomcat

(6)demo2获取到请求后,从请求头中就读取cookie中的JSESSIONID值为10,然后就会到服务器内存中寻找id:10的session对象,如果找到了,就直接返回该对象,如果没有则新创建一个session对象

(7)关闭打开浏览器后,因为浏览器的cookie已被销毁,所以就没有JESSIONID的数据,服务端获取到的session就是一个全新的session对象

《实际演示》使用谷歌浏览器访问http://localhost:8080/demo1,并按下F12查看

使用谷歌浏览器访问http://localhost:8080/demo2,并按下F12查看Session详解(sessionn)

3.3、Session的使用细节

在使用Session时注意下面两点细节:第一个是Session的钝化和活化,第二个是Session的销毁

3.3.1、Session钝化与活化

由于Session对象是存储在服务器内存中的,所以Session中的数据在重启服务器后就会被释放,Session对象也会被销毁。

Session对象被销毁会引发什么问题?

当我们在购物车购物时,我们因为打电话等其他原因导致付钱的动作被搁置,这时服务器重启了,Session对象消失了,我们的数据也没了,这就会导致很不好的影响,所以我们需要在服务器即使重启的情况下也要将用户的数据保存下来。

《测试正常启动和关闭Tomcat服务器,Session会不会消失》正常启动Tomcat(使用Maven Helper插件)

进入到项目文件夹中,在终端使用以下命令:

mvn tomcat7:run

注:若启动失败,尝试清除浏览器本地Cookie缓存

访问http://localhost:8080/cookie-demo/demo1,再访问http://localhost:8080/cookie-demo/demo2,查看控制台输出

正常关闭Tomcat服务器:Ctrl + c再次启动,访问http://localhost:8080/cookie-demo/demo2,查看控制台输出

经过测试,只要服务器是正常关闭和启动,session中的数据是可以被保存下来的,原因就是Session的钝化和活化

钝化:在服务器正常关闭后,Tomcat会自动将Session数据写入硬盘的文件中

钝化的数据路径为:项目目录\target\tomcat\work\Tomcat\localhost\项目名称\SESSIONS.ser

活化:再次启动服务器后,从文件中加载数据到新的Session中

数据加载到Session中后,路径中的SESSIONS.ser文件会被删除掉

小结:

session数据存储在服务端,服务器重启后,session数据会被保存

浏览器被关闭启动后,重新建立的连接就已经是一个全新的会话,获取的session数据也是一个新的对象

session的数据要想共享,浏览器不能关闭,所以session数据不能长期保存数据

cookie是存储在客户端,是可以长期保存

3.3.2、Session的销毁

session的销毁会有两种方式:

默认情况下,无操作,30分钟自动销毁

可以在web.xml文件中配置修改失效时间(单位:分钟)

<?xml version="1.0" encoding="UTF-8"?><web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd" version="4.0"> <session-config> <session-timeout>100</session-timeout> </session-config></web-app>

如果没有配置,默认是30分钟,默认值是在Tomcat的web.xml配置文件中写死的

调用Session对象的invalidate()进行销毁

在SessionDemo2类中添加session销毁的方法

@WebServlet("/demo2")public class SessionDemo2 extends HttpServlet { @Override protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { //获取数据,从session中 //1. 获取Session对象 HttpSession session = request.getSession(); System.out.println(session); // 销毁 session.invalidate(); //2. 获取数据 Object username = session.getAttribute("username"); System.out.println(username); } @Override protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { this.doGet(request, response); }}

该销毁方法一般会在用户退出的时候,需要将session销毁掉。

4、小结

Cookie和Session共同目标:Cookie 和 Session 都是来完成一次会话内多次请求间数据共享的。

Cookie和Session的区别:

存储位置:Cookie 是将数据存储在客户端,Session 将数据存储在服务端安全性:Cookie不安全,Session安全数据大小:Cookie最大3KB,Session无大小限制存储时间:Cookie可以通过setMaxAge()长期存储,Session默认30分钟服务器性能:Cookie不占服务器资源,Session占用服务器资源

Cookie和Session的应用场景:

购物车:使用Cookie来存储以登录用户的名称展示:使用Session来存储记住我功能:使用Cookie来存储验证码:使用session来存储

结论:

Cookie是用来保证用户在未登录情况下的身份识别Session是用来保存用户登录后的数据

尾言:创作不易,如果本文的内容对您有帮助,还望客官可以三连支持一下博主,👍(点赞)+✏️(评论)+⭐️(收藏)是我创作的巨大动力!

本文链接地址:https://www.jiuchutong.com/zhishi/298770.html 转载请保留说明!

上一篇:face_recognition库的使用(face_recognition库采用了什么算法)

下一篇:JS获取各种屏幕的宽度和高度(js获取各种屏幕信息)

  • 怎么把桌面路径设置到D盘(怎么把桌面路径改到d盘)

    怎么把桌面路径设置到D盘(怎么把桌面路径改到d盘)

  • word字体怎么旋转180度(word字体怎么旋转1)

    word字体怎么旋转180度(word字体怎么旋转1)

  • wps文本框的边框如何去掉(wps文本框的边框怎么设置)

    wps文本框的边框如何去掉(wps文本框的边框怎么设置)

  • 淘宝618从什么时间开始(淘宝618什么时候发货)

    淘宝618从什么时间开始(淘宝618什么时候发货)

  • Word横版打印怎么设置(word怎么横版)

    Word横版打印怎么设置(word怎么横版)

  • 拼多多导入订单不发货的原因(拼多多订单导出怎么操作)

    拼多多导入订单不发货的原因(拼多多订单导出怎么操作)

  • iphonex前置摄像头模糊(IPhonex前置摄像头容易进灰尘)

    iphonex前置摄像头模糊(IPhonex前置摄像头容易进灰尘)

  • 摄像头不聚焦怎么回事(摄像头不聚焦模糊是什么原因?)

    摄像头不聚焦怎么回事(摄像头不聚焦模糊是什么原因?)

  • h3c路由器亮橙色灯怎么处理(h3c magic r365路由器亮橙色的灯是坏了吗?)

    h3c路由器亮橙色灯怎么处理(h3c magic r365路由器亮橙色的灯是坏了吗?)

  • 无线局域网和Wi-Fi区别(无线组网)

    无线局域网和Wi-Fi区别(无线组网)

  • 美国第一台计算机诞生于什么时候(美国第一台计算机缩写)

    美国第一台计算机诞生于什么时候(美国第一台计算机缩写)

  • 腾讯会议可以看到每个人吗(腾讯会议可以看见成员在线时长吗)

    腾讯会议可以看到每个人吗(腾讯会议可以看见成员在线时长吗)

  • 为什么闲鱼突然没有曝光率了(为什么闲鱼突然人少了)

    为什么闲鱼突然没有曝光率了(为什么闲鱼突然人少了)

  • micc9meitu edition是小米什么型号

    micc9meitu edition是小米什么型号

  • 快手可以艾特自己吗(快手艾特自己话题)

    快手可以艾特自己吗(快手艾特自己话题)

  • 电池容量和额定容量有什么区别(电池容量和额定能量)

    电池容量和额定容量有什么区别(电池容量和额定能量)

  • 抖音发布后还能修改吗(抖音发布后还能加标题吗)

    抖音发布后还能修改吗(抖音发布后还能加标题吗)

  • word页面设置在哪(word页面设置在哪个菜单栏)

    word页面设置在哪(word页面设置在哪个菜单栏)

  • 酷狗怎么把歌词放桌面(酷狗怎么把歌词弄到屏幕上)

    酷狗怎么把歌词放桌面(酷狗怎么把歌词弄到屏幕上)

  • 苹果7p分辨率(苹果13的屏幕分辨率)

    苹果7p分辨率(苹果13的屏幕分辨率)

  • 手机充电发热是什么原因(手机充电发热是不是电池坏了)

    手机充电发热是什么原因(手机充电发热是不是电池坏了)

  • 快手为什么分享不了微信朋友圈(快手为什么分享不出去)

    快手为什么分享不了微信朋友圈(快手为什么分享不出去)

  • 拼多多物流异常订单怎么消除(拼多多物流异常限制金额永远都限制吗)

    拼多多物流异常订单怎么消除(拼多多物流异常限制金额永远都限制吗)

  • 设备管理在哪(描述文件与设备管理在哪)

    设备管理在哪(描述文件与设备管理在哪)

  • vivox9s照片删了怎么恢复(vivox9s手机照片删除后在哪找回)

    vivox9s照片删了怎么恢复(vivox9s手机照片删除后在哪找回)

  • qq的svip有什么用(qq的svip能干什么)

    qq的svip有什么用(qq的svip能干什么)

  • 面对面建群谁是群主(面对面建群谁是群主如何踢人)

    面对面建群谁是群主(面对面建群谁是群主如何踢人)

  • 体重秤充电多长时间(体重秤充电多长时间最好用)

    体重秤充电多长时间(体重秤充电多长时间最好用)

  • 奥卡拉国家森林中的杜松泉,美国佛罗里达州 (© Michael Warren/Getty Images)(奥卡拉国家森林公园)

    奥卡拉国家森林中的杜松泉,美国佛罗里达州 (© Michael Warren/Getty Images)(奥卡拉国家森林公园)

  • 所得税五个年度怎么算
  • 租赁办公场所的请示
  • 减免的养老保险怎么走账
  • 计提工资和实际发放工资必须一致吗
  • 免抵退的意思
  • 个人转让土地使用权
  • 公司工会的主要职能是
  • 事业单位无形资产摊销
  • 房地产开发企业土地增值税清算
  • 公司聚餐费用标准
  • 城镇垃圾处理费计入什么科目
  • 高温补贴领取
  • 其他应收款 应收账款
  • 增值税抵扣联退税多少
  • 合同银行账户与开票信息不一致会计如何处理
  • 公司没有实缴可以破产么
  • 推广费属于什么税收编码
  • 王者荣耀中孙尚香怎么玩
  • 公司入股的钱怎么做账
  • vue做移动端适配最佳解决方案,亲测有效
  • 短期借款利息怎么做分录
  • yolov5 c
  • 新准则委托代建 不得管理费
  • gpt详解
  • php实现分页显示
  • 浅谈socket同步和异步、阻塞和非阻塞、I/O模型
  • api接口使用方法
  • 前后端分离弊端
  • wordpress安装插件无法复制
  • 固定资产一次性扣除政策
  • 新公司建账会计科目
  • 对公账户和私人账户怎么区分
  • 公司减持股份是利好还是利空
  • 资产处置损益是什么类
  • 购买汽车相关费用标准
  • mysql查询数据库前五条信息
  • PHP MongoDB GridFS 存储文件的方法详解
  • mongodb reference
  • 预收款项可以开发票吗
  • sql2008怎么查询
  • 金税四期对企业纳税管理影响分析
  • 股东收到投资收益会计科目
  • 个人所得税由单位还是个人缴纳
  • 电子税务局没有增值税申报怎么办?
  • 应付账款的入账时间为
  • 内账会计的主要工作
  • 一般纳税人不得领用专票的情形
  • 免抵退 免退
  • 其他综合收益为什么不影响利润
  • 销售合同的印花税由谁交
  • 委托加工物资的加工费计入什么科目
  • 小规模转一般纳税人条件最新政策
  • 期初与年初有什么区别
  • 固定制造费用包括变动制造费用吗
  • 生产成本工时怎么算
  • 发票抬头是个人税号怎么填
  • 苗木补偿款
  • sqlserver2000怎么用
  • mysql好在哪里
  • mysql sql 基础教程
  • 在Windows Server 2008中配置FTP服务
  • win8连接wifi界面消失
  • linux计划任务怎么写
  • 卸载声卡驱动有什么影响
  • 如何重置win10
  • windows10周年纪念版
  • pascl32.exe - pascl32是什么进程 有什么用
  • cocos2dx 3.17
  • jquery判断div是否显示
  • jquery animate源码
  • Android计算器项目代码
  • Android SQLite总结(一)
  • PreferenceActivity、PreferenceFragment使用
  • vuex按需加载
  • jquery遍历元素并赋值
  • python作用域和优先级
  • 欢迎使用来电提醒业务是什么意思
  • 文化公司税务筹划
  • 深圳市的各区域排名
  • 新税法折旧年限怎么算
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设