Java Web 之 Session 详解

在 JavaWeb 开发中,Session 就像网站的专属记忆管家,为每个用户保管着重要的信息和状态,确保用户在网站的旅程顺畅无阻。

场景一:

想象你去一家大型超市购物,推着购物车挑选商品。这个购物车就如同 Session,它记录了你的购物信息,方便你在结账时一次性结算。

场景二:

你在玩一个在线游戏,登录账号后,你的游戏进度、等级、装备等信息都会被保存在 Session 中,即使你中途关闭游戏,下次登录时依然可以继续之前的进度。

一、Session 的基础知识

Session 是一种服务器端的技术,用于存储用户的状态信息。在 Web 开发中,Session 通常用于跟踪用户在应用程序中的活动,存储用户特定的信息,如登录状态、购物车内容等。Session 的生命周期指的是从创建到销毁的整个过程。以下是 Session 生命周期的一般概述:

  • 创建 Session

    • 当用户首次访问 Web 应用程序时,如果应用程序配置为使用 Session,服务器会自动为该用户创建一个新的 Session。这通常发生在用户发送第一个请求到服务器时。
    • Session 创建后,服务器会生成一个唯一的 Session ID,用于标识这个 Session。这个 ID 通常会存储在用户的 Cookie 中,或者以其他方式(如 URL 参数)传递给客户端。
  • 使用 Session

    • 用户在应用程序中的每次请求都会携带 Session ID,服务器通过这个 ID 来检索和更新用户的 Session 数据。
    • 开发者可以在服务器端的代码中通过 Session 对象来存取和修改用户的状态信息。
  • Session 的过期

    • Session 可以设置一个过期时间,这个时间可以是固定的,也可以是基于用户的活动动态计算的。
    • 当 Session 超过设定的有效期而没有新的请求发生时,Session 将自动失效。
    • 一些 Web 服务器允许设置 Session 的最大非活动时间,即在这段时间内如果没有新的请求,Session 将被销毁。
  • 手动销毁 Session

    • 开发者可以在代码中显式地销毁 Session,这通常发生在用户注销或完成某些操作后。
    • 当 Session 被销毁时,服务器会清除与该 Session 相关联的所有数据。
  • Session 的终止

    • 当用户关闭浏览器时,存储在浏览器中的 Session ID 通常会丢失,除非 Session 被设置为持久化存储。
    • 如果服务器端的 Session 数据没有被清除,即使用户关闭了浏览器,下次使用相同的设备和浏览器访问时,Session 仍然可以被恢复。
  • 服务器端配置

    • Session 的生命周期和行为可以通过服务器端的配置进行调整,例如在 Tomcat 中可以通过 web.xml 文件或注释来设置 Session 的超时时间。

在 Java Servlet API 中,Session 的生命周期可以通过 HttpSession 接口来管理,例如使用 session.setMaxInactiveInterval(int interval) 方法来设置 Session 的最大非活动时间。

二、Session 的本质

Session 就像网站服务器端的“大脑”,它为每个用户分配了一个独一无二的“记忆卡”(Session ID),并将用户的相关信息存储在服务器端的“保险柜”(Session 存储)中,确保用户信息的安全和私密性。

应用场景:

  1. 用户登录: 存储用户的登录状态,免除用户每次访问都需要重新登录的麻烦。

  2. 购物车: 存储用户的购物车信息,即使关闭浏览器,购物车里的商品依然乖乖等待着用户。

  3. 个性化推荐: 根据用户的浏览历史和购买记录,推荐用户可能感兴趣的产品或服务,就像贴心的导购员一样。

  4. 访问控制: 控制用户对网站特定功能或页面的访问权限,就像网站的“保安”,守护着网站的安全。

三、Session 工作原理

  1. 创建 Session: 当用户首次访问网站时,服务器会为该用户创建一个独一无二的 Session ID,并将该 ID 存储在用户的浏览器 Cookie 中,就像给用户发放了一张专属的“记忆卡”。

  2. 维护 Session: 用户每次访问网站时,浏览器都会自动将 Session ID 发送给服务器,服务器根据 Session ID 找到对应的 Session 数据,并进行相应的操作,就像用户每次购物都带着“记忆卡”一样。

  3. 销毁 Session: 当用户关闭浏览器、Session 超时或服务器主动销毁时,Session 就会失效,服务器会清除该 Session 对应的所有数据,就像用户离开超市后,“购物车”被清空一样。

四、Java Servlet API 中的 Session 操作

  • 获取 Session 对象:

HttpSession session = request.getSession(); // 获取当前用户的 Session 对象,如果不存在则创建
HttpSession session = request.getSession(true); // 同上,如果不存在则创建
HttpSession session = request.getSession(false); // 获取当前用户的 Session 对象,如果不存在则返回 null
  • 存储数据到 Session:

session.setAttribute("username", "Bob"); // 将用户名存储到 Session 中,就像把商品放入购物车
  • 从 Session 中读取数据:

String username = (String) session.getAttribute("username"); // 从 Session 中获取用户名,就像查看购物车里的商品
  • 删除 Session 数据:

session.removeAttribute("username"); // 删除 Session 中的用户名,就像把商品从购物车中移除
  • 销毁 Session:

session.invalidate(); // 销毁当前用户的 Session,就像清空购物车并离开超市

五、使用 Session 的示例

以下是一个简单的例子,演示了如何使用 Session 记录用户登录状态:

import javax.servlet.ServletException;
import javax.servlet.http.*;
import java.io.IOException;public class SessionServlet extends HttpServlet {protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {// 获取 Session 对象HttpSession session = request.getSession();// 获取 Session 中存储的用户名String username = (String) session.getAttribute("username");// 如果用户名不为空,则说明用户已登录if (username != null) {response.getWriter().println("欢迎回来," + username + "!");} else {// 用户未登录,跳转到登录页面response.sendRedirect("login.jsp");}}
}

六、Session 的安全性

Session 数据存储在服务器端,比存储在客户端 Cookie 更安全可靠(cookie知识详解),但仍然需要注意以下安全问题:

  • Session 劫持: 攻击者可以通过窃取用户的 Session ID 来冒充用户身份,访问用户的敏感信息。

  • 跨站请求伪造(CSRF): 攻击者可以通过诱导用户访问恶意链接,利用用户的 Session ID 发送伪造请求,进行恶意操作。

七、Session 的限制

  • 占用服务器资源: Session 数据存储在服务器内存中,如果用户量过大,会占用大量的服务器内存资源。

  • 依赖 Cookie: Session ID 通常存储在 Cookie 中,如果用户禁用 Cookie,Session 就无法正常工作。

八、Session 的替代方案

  • JWT(JSON Web Token): 一种基于 JSON 的开放标准,用于在各方之间安全地传输信息。

  • OAuth 2.0: 一种授权框架,允许第三方应用程序在用户授权的情况下访问用户的资源,而无需获取用户的用户名和密码。

九、Session 的优缺点

优点:

  • 安全性高: Session 数据存储在服务器端,不易被窃取或篡改。

  • 存储容量大: Session 可以存储更多的数据,不受浏览器 Cookie 大小限制。

缺点:

  • 增加服务器负担: Session 数据存储在服务器端,会占用服务器内存资源。

  • 依赖 Cookie: Session ID 通常存储在 Cookie 中,如果用户禁用 Cookie,Session 就无法正常工作。

十、总结

Session 就像网站的幕后英雄,默默地守护着用户的会话状态,提供更加安全、个性化的用户体验。了解 Session 的工作原理、应用场景以及安全问题,可以帮助我们更好地开发 Web 应用,为用户打造一个安全、便捷的网络世界。希望对各位看官有所帮助,感谢各位看官的观看,下期见,谢谢~

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/55198.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

本地访问autodl的jupyter notebook

建立环境并安装jupyter conda create --name medkg python3.10 source activate medkg pip install jupyter 安装完成后,输入jupyter notebook --generate-config 输入ipython,进入python In [2]: from jupyter_server.auth import passwd In [3]: passwd(algori…

Spring Data(学习笔记)

JPQL语句???(Query括号中的就是JPQL语句) 怎么又会涉及到连表查询呢? 用注解来实现表间关系。 分页是什么?为什么什么都有分页呢 ? 继承,与重写方法的问题 Deque是什么 ?…

在Ubuntu 14.04上安装带SSL的Webmin的方法

前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站。 简介 Webmin 是一个基于 Web 的类 Unix 系统管理工具。它提供了一个简单的替代方案来进行命令行系统管理,并可以通过提供的…

【JavaSE】反射、枚举、lambda表达式

目录 反射反射相关类获取类中属性相关方法常用获得类相关的方法示例常用获得类中属性相关的方法示例获得类中注解相关的方法 反射优缺点 枚举常用方法优缺点 枚举与反射lambda表达式语法函数式接口简化规则使用示例变量捕获集合中的应用优缺点 反射 Java的反射(refl…

通信协议感悟

本文结合个人所学,简要讲述SPI,I2C,UART通信的特点,限制。 1.同步通信 UART,SPI,I2C三种串行通讯方式,SPI功能引脚为CS,CLK,MOSI,MISO;I2C功能引…

若依从redis中获取用户列表

因为若依放入用户的时候&#xff0c;会在减值中添加随机串&#xff0c;所以用户的key会在redis中变成&#xff1a; login_tokens:6af07052-b76d-44dd-a296-1335af03b2a6 这样的样子。 如果用 Set<Object> items redisService.redisTemplate.keys("login_tokens&…

dcatadmin 自定义登录页面

一、问题&#xff1a; 在后台管理系统中&#xff0c;不同的项目想要不同的登录页面&#xff0c;但是框架自带的登录页面就只有一个。 解决&#xff1a; 由芒果系统改造的dcatadmin登录插件&#xff0c;实现一键安装改变登录页面。 项目介绍 基于Laravel和Vue的快速开发的后台管…

YOLO11改进 | 检测头 | 小目标遮挡物性能提升的检测头Detect_MultiSEAM【完整代码】

秋招面试专栏推荐 &#xff1a;深度学习算法工程师面试问题总结【百面算法工程师】——点击即可跳转 &#x1f4a1;&#x1f4a1;&#x1f4a1;本专栏所有程序均经过测试&#xff0c;可成功执行&#x1f4a1;&#x1f4a1;&#x1f4a1; 基于深度学习的人脸检测算法取得了巨大进…

方法与方法重载

方法参数传递 方法语法&#xff1a; 访问修饰符 返回值类型 方法名&#xff08;形参列表&#xff09;{方法体[return 返回值] } 对象名.方法名&#xff08;实参列表&#xff09;注意&#xff1a;形参和实参一一对应&#xff08;个数和类型&#xff09; package com.hz.test12…

javax.net.ssl.SSLHandshakeException: Chain validation failed

异常描述&#xff1a; D/OkHttp: <-- HTTP FAILED: javax.net.ssl.SSLHandshakeException: Chain validation failed com.bfmd.okhttpsample I/Main: error: Chain validation failed异常解决&#xff1a; 解决方法一&#xff1a; 解决方法很简单&#xff0c;检查一下设备…

PID控制原理:看下这三个故事,你就明白了

一、PID的故事 小明接到这样一个任务&#xff1a;有一个水缸点漏水(而且漏水的速度还不一定固定不变)&#xff0c;要求水面高度维持在某个位置&#xff0c;一旦发现水面高度低于要求位置&#xff0c;就要往水缸里加水。 小明接到任务后就一直守在水缸旁边&#xff0c;时间长就觉…

SEO友好的wordpress模板 应该具体哪些特征

在数字营销的时代&#xff0c;搜索引擎优化(SEO)对于任何网站来说都是至关重要的。WordPress作为全球最受欢迎的内容管理系统之一&#xff0c;提供了大量的模板(也称为主题)供用户选择。一个SEO友好的WordPress模板不仅可以帮助您的网站在搜索引擎中获得更好的排名&#xff0c;…

遇到慢SQL、SQL报错,应如何快速定位问题 | OceanBase优化实践

在数据库的使用中&#xff0c;大家时常会遇到慢SQL&#xff0c;或执行出错的SQL。对于某些SQL问题&#xff0c;其错误原因显而易见&#xff0c;但也有不少情况难以直观判断。面对这类问题&#xff0c;我们应当如何应对&#xff1f;如何准确识别SQL错误的根源&#xff1f;是否需…

嵌入向量生成与查询

嵌入向量生成与查询 文本嵌入模型 M3E 是 Moka Massive Mixed Embedding 的缩写 Moka&#xff0c;此模型由 MokaAI 训练&#xff0c;开源和评测&#xff0c;训练脚本使用 uniem&#xff0c;评测 BenchMark 使用 MTEB-zh Massive&#xff0c;此模型通过千万级 (2200w) 的中文句…

用于高频交易预测的最优输出LSTM

用于高频交易预测的最优输出LSTM J.P.Morgan的python教程 Content 本文提出了一种改进的长短期记忆&#xff08;LSTM&#xff09;单元&#xff0c;称为最优输出LSTM&#xff08;OPTM-LSTM&#xff09;&#xff0c;用于实时选择最佳门或状态作为最终输出。这种单元采用浅层拓…

MongoDB mongoose 的 save、insert 和 create 方法的比较

目录 save 方法 insert 方法 create 方法 使用会话和事务 总结 在本文中&#xff0c;我们将介绍 MongoDB 中使用 mongoose 操作 数据库时的三种常见方法&#xff1a;save、insert 和 create。这些方法可以用于将数据存储到 MongoDB 数据库中&#xff0c;并且在一定程度上具…

Study-Oracle-10-ORALCE19C-RAC集群搭建(一)

一、硬件信息及配套软件 1、硬件设置 RAC集群虚拟机:CPU:2C、内存:10G、操作系统:50G Openfile数据存储:200G (10G*2) 2、网络设置 主机名公有地址私有地址VIP共享存储(SAN)rac1192.168.49.13110.10.10.20192.168.49.141192.168.49.130rac2192.168.49.13210.10.10.3…

Python、PyTorch与cuda的版本对应表

常见的Python和PyTorch版本对应关系。 PyTorch版本对应的PythonPyTorch1.0Python 2.7&#xff0c;3.5&#xff0c;3.6&#xff0c;3.7PyTorch1.1Python 2.7&#xff0c;3.5&#xff0c;3.6&#xff0c;3.7PyTorch1.2Python 2.7&#xff0c;3.5&#xff0c;3.6&#xff0c;3.7P…

基于深度学习的不遗忘训练

基于深度学习的不遗忘训练&#xff08;也称为抗遗忘训练或持久性学习&#xff09;是针对模型在学习新任务时可能会忘记已学习内容的一种解决方案。该方法旨在使深度学习模型在不断接收新信息的同时&#xff0c;保持对旧知识的记忆。以下是这一领域的主要内容和方法&#xff1a;…

深度学习中的卷积神经网络

在深度学习的世界中&#xff0c;卷积神经网络&#xff08;Convolutional Neural Networks&#xff0c;简称CNN&#xff09;是一种重要的模型。它特别适用于处理具有网格状拓扑结构的数据&#xff0c;如图像和视频。本文将深入探讨CNN的工作原理&#xff0c;以及如何利用它们来处…