当前位置: 首页 > news >正文

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 应用,为用户打造一个安全、便捷的网络世界。希望对各位看官有所帮助,感谢各位看官的观看,下期见,谢谢~

相关文章:

Java Web 之 Session 详解

在 JavaWeb 开发中,Session 就像网站的专属记忆管家,为每个用户保管着重要的信息和状态,确保用户在网站的旅程顺畅无阻。 场景一: 想象你去一家大型超市购物,推着购物车挑选商品。这个购物车就如同 Session&#xff…...

63.5 注意力提示_by《李沐:动手学深度学习v2》pytorch版

系列文章目录 文章目录 系列文章目录注意力提示生物学中的注意力提示查询、键和值注意力的可视化使用 show_heatmaps 显示注意力权重代码示例 代码解析结果 小结练习 注意力提示 🏷sec_attention-cues 感谢读者对本书的关注,因为读者的注意力是一种稀缺…...

vscode 的terminal 输出打印行数限制设置

修改 VSCODE 的 settings.json文件 "terminal.integrated.scrollback": 100000, {"extensions.ignoreRecommendations": true,"workbench.colorTheme": "Monokai","explorer.confirmDelete": false,"editor.fontSize…...

深入挖掘C++中的特性之一 — 继承

目录 1.继承的概念 2.举个继承的例子 3.继承基类成员访问方式的变化 1.父类成员的访问限定符对在子类中访问父类成员的影响 2.父类成员的访问限定符子类的继承方式对在两个类外访问子类中父类成员的影响 4.继承类模版(注意事项) 5.父类与子类间的转…...

Linux 下 poll 详解

在Linux系统编程中,poll 是一个强大的多路复用(I/O 多路复用)函数,用于同时监控多个文件描述符的事件,特别是在处理网络套接字或其他I/O设备时。相比于select,poll 支持监控更多的文件描述符,并…...

virtualbox配置为NAT模式后物理机和虚拟机互通

virtualbox配置为 NAT模式后,虚拟机分配到的 IP地址一般是 10.xx网段的,虚拟机可以通过网络地址转换访问物理机所在的网络,但若不做任何配置,则物理机无法直接访问虚拟机。 virtualbox在提供 NAT配置模式时,也提供了端…...

工程机械车辆挖掘机自卸卡车轮式装载机检测数据集VOC+YOLO格式2644张3类别

数据集格式:Pascal VOC格式YOLO格式(不包含分割路径的txt文件,仅仅包含jpg图片以及对应的VOC格式xml文件和yolo格式txt文件) 图片数量(jpg文件个数):2644 标注数量(xml文件个数):2644 标注数量(txt文件个数):2644 标注…...

[Notepad++] 文本编辑器的下载及详细安装使用过程(附有下载文件)

程序员常用的文本编辑器Notepad,用于修改配置文件等 下载链接在文末 下载压缩包后解压 !!安装路径不要有中文 解压文件,得到 双击exe文件 选择简体中文,点击OK 点击下一步 点击“我接受” 更改安装目录,不…...

深入浅出Java多线程(六):Java内存模型

引言 大家好,我是你们的老伙计秀才!今天带来的是[深入浅出Java多线程]系列的第六篇内容:Java内存模型。大家觉得有用请点赞,喜欢请关注!秀才在此谢过大家了!!! 在并发编程中&#xf…...

注册了个小趴菜999#it#com

注册了个 999#it#com 拿着玩玩吧 现在二级域名竟然也让注册了 不过cn.com的二级似乎早就可以了...

UE4 材质学习笔记02(数据类型/扭曲着色器)

一.什么是数据类型 首先为啥理解数据类型是很重要的。一些节点的接口插槽只接受特定类型的数据,如果连接了不匹配的数据就会出现错误,有些接口可以接受任何数据类型,但是实际上只会使用到其中的一些。并且有时可以将多个数据流合并成一个来编…...

Linux驱动开发(速记版)--设备树插件

第六十八章 设备树插件介绍 Linux 4.4之后引入了动态设备树,其中的设备树插件(Device Tree Overlay)是一种扩展机制,允许在运行时动态添加、修改或删除设备节点和属性。 设备树插件机制通过DTS(设备树源文件&#xff0…...

代码报错后如何定位问题

文章目录 一、查看终端报错Exception二、百度三、问 一、查看终端报错Exception 代码报错时,终端一般都会有xxxException异常提示,或者exception、error…等字样提示,就顺着这些关键字提醒找到异常即可。 二、百度 不知道这个英文的异常是…...

Python数据可视化--Matplotlib--入门

我生性自由散漫,不喜欢拘束。我谁也不爱,谁也不恨。我没有欺骗这个,追求那个;没有把这个取笑,那个玩弄。我有自己的消遣。 -- 塞万提斯 《堂吉诃德》 Matplotlib介绍 1. Matplotlib 是 Python 中常用的 2D 绘图库&a…...

美国食品等级FDA认证测试介绍

美国FDA认证概览 美国食品和药物管理局(FDA)是负责监管食品、药品、医疗设备和化妆品等的联邦机构,以确保这些产品对公众健康和安全的影响。FDA认证在美国属于强制性认证,对产品的安全性和质量有着严格的要求。通过FDA认证&#…...

Vue2如何在网页实现文字的逐个显现

目录 Blue留言: 效果图: 实现思路: 代码: 1、空字符串与需渲染的字符串的定义 2、vue的插值表达式 3、函数 4、mounted()函数调用 结语: Blue留言: 在国庆前夕,突发奇想,我想…...

mybatisplus的查询,分页查询,自定义多表查询,修改的几种写法

使用mybatisplus的Db类简化写法 使用静态调用的方式,执行CRUD方法,避免Spring环境下Service循环注入、简洁代码,提升效率需要项目中已注入对应实体的BaseMapper完整使用方式见官方测试用例:官方测试用例地址对于参数为Wrapper的&…...

括号匹配判断

本题实现求表达式中括号是否匹配。只需判断表达式中括号(本题中只会出现三种括号,分别是小括号,中括号和大括号)是否匹配,表达式中可以有其他值也可没有。 函数接口定义: int match (char *exp); 其中 …...

数据结构(栈和队列的实现)

1. 栈(Stack) 1.1 栈的概念与结构 栈是一种特殊的线性表,其只允许固定的一段插入和删除操作;进行数据插入和删除的一段叫做栈顶,另一端叫栈底;栈中的元素符合后进先出LIFO(Last In First Out&…...

Python批量处理客户明细表格数据,挖掘更大价值

批量处理 .xls 数据并进行归类分析以挖掘内在价值,通常涉及以下步骤: 读取数据:使用 pandas 库读取 .xls 文件。数据清洗:处理缺失值、异常值、重复值等。数据转换:对数据进行必要的转换,如日期格式统一、…...

Robots.txt 文件

什么是robots.txt? robots.txt 是一个位于网站根目录下的文本文件(如:https://example.com/robots.txt),它用于指导网络爬虫(如搜索引擎的蜘蛛程序)如何抓取该网站的内容。这个文件遵循 Robots…...

12.找到字符串中所有字母异位词

🧠 题目解析 题目描述: 给定两个字符串 s 和 p,找出 s 中所有 p 的字母异位词的起始索引。 返回的答案以数组形式表示。 字母异位词定义: 若两个字符串包含的字符种类和出现次数完全相同,顺序无所谓,则互为…...

深入解析C++中的extern关键字:跨文件共享变量与函数的终极指南

🚀 C extern 关键字深度解析:跨文件编程的终极指南 📅 更新时间:2025年6月5日 🏷️ 标签:C | extern关键字 | 多文件编程 | 链接与声明 | 现代C 文章目录 前言🔥一、extern 是什么?&…...

深度学习水论文:mamba+图像增强

🧀当前视觉领域对高效长序列建模需求激增,对Mamba图像增强这方向的研究自然也逐渐火热。原因在于其高效长程建模,以及动态计算优势,在图像质量提升和细节恢复方面有难以替代的作用。 🧀因此短时间内,就有不…...

【JavaSE】多线程基础学习笔记

多线程基础 -线程相关概念 程序(Program) 是为完成特定任务、用某种语言编写的一组指令的集合简单的说:就是我们写的代码 进程 进程是指运行中的程序,比如我们使用QQ,就启动了一个进程,操作系统就会为该进程分配内存…...

R 语言科研绘图第 55 期 --- 网络图-聚类

在发表科研论文的过程中,科研绘图是必不可少的,一张好看的图形会是文章很大的加分项。 为了便于使用,本系列文章介绍的所有绘图都已收录到了 sciRplot 项目中,获取方式: R 语言科研绘图模板 --- sciRplothttps://mp.…...

AI语音助手的Python实现

引言 语音助手(如小爱同学、Siri)通过语音识别、自然语言处理(NLP)和语音合成技术,为用户提供直观、高效的交互体验。随着人工智能的普及,Python开发者可以利用开源库和AI模型,快速构建自定义语音助手。本文由浅入深,详细介绍如何使用Python开发AI语音助手,涵盖基础功…...

MySQL 主从同步异常处理

阅读原文:https://www.xiaozaoshu.top/articles/mysql-m-s-update-pk MySQL 做双主,遇到的这个错误: Could not execute Update_rows event on table ... Error_code: 1032是 MySQL 主从复制时的经典错误之一,通常表示&#xff…...

实战三:开发网页端界面完成黑白视频转为彩色视频

​一、需求描述 设计一个简单的视频上色应用,用户可以通过网页界面上传黑白视频,系统会自动将其转换为彩色视频。整个过程对用户来说非常简单直观,不需要了解技术细节。 效果图 ​二、实现思路 总体思路: 用户通过Gradio界面上…...

系统掌握PyTorch:图解张量、Autograd、DataLoader、nn.Module与实战模型

本文较长,建议点赞收藏,以免遗失。更多AI大模型应用开发学习视频及资料,尽在聚客AI学院。 本文通过代码驱动的方式,系统讲解PyTorch核心概念和实战技巧,涵盖张量操作、自动微分、数据加载、模型构建和训练全流程&#…...