Java Web 之 Session 详解

news2024/10/1 19:30:05

在 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.coloradmin.cn/o/2183009.html

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

相关文章

SpringBoot项目 | 瑞吉外卖 | 短信发送验证码功能改为免费的邮箱发送验证码功能 | 代码实现

0.前情提要 之前的po已经说了单独的邮箱验证码发送功能怎么实现: https://blog.csdn.net/qq_61551948/article/details/142641495 这篇说下如何把该功能整合到瑞吉项目里面,也就是把原先项目里的短信发送验证码的功能改掉,改为邮箱发送验证…

World of Warcraft [CLASSIC][80][Grandel] /console cameraDistanceMaxZoomFactor 2

学习起来!!! 调整游戏界面镜头距离,默认值为:2 /console cameraDistanceMaxZoomFactor 2 大于4,效果不明显了,鼠标滚轮向后滚,拉起来镜头 World of Warcraft [CLASSIC][80][Grandel…

Another redis desktop manager使用说明

Another redis desktop manager使用说明 概述界面介绍图示说明连接界面设置界面查看操作日志主界面信息进入redis-cli控制台更多 概述 Another Redis Desktop Manager是一个开源的跨平台 Redis 客户端,提供了简洁易用的图形用户界面(GUI)&am…

第5篇:勒索病毒自救指南----应急响应篇

经常会有一些小伙伴问:中了勒索病毒,该怎么办,可以解密吗? 第一次遇到勒索病毒是在早几年的时候,客户因网站访问异常,进而远程协助进行排查。登录服务器,在站点目录下发现所有的脚本文件及附件…

【JaveEE】——多线程中使用顺序表,队列,哈希表

阿华代码,不是逆风,就是我疯 你们的点赞收藏是我前进最大的动力!! 希望本文内容能够帮助到你!! 目录 一:多线程环境使用ArrayList 引入: 1:顺序表使用同步机制 2&…

Linux服务器配置anaconda3,下载torch

如图,vscode连接远程服务器后,如下所示: 下载 Anaconda 下载及安装 进入下载官网,点击linux, 下载方式有两种, 直接下载安装包,下载完上传服务器,并安装,安装执行b…

【算法系列-链表】移除链表元素

【算法系列-链表】移除链表元素 欢迎来到【算法系列】第二弹 🏆 链表,接下来我们将围绕链表这类型的算法题进行解析与练习!一起加油吧!!( •̀ ω •́ )✧✨ 文章目录 【算法系列-链表】移除链表元素1. 算法分析&am…

Spring Data(学习笔记)

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

线程池:线程池的实现 | 日志

🌈个人主页: 南桥几晴秋 🌈C专栏: 南桥谈C 🌈C语言专栏: C语言学习系列 🌈Linux学习专栏: 南桥谈Linux 🌈数据结构学习专栏: 数据结构杂谈 🌈数据…

C++容器之vector模拟实现(代码纯享版!!!)

目录 前言 一、头文件 .h文件 总结 前言 本文是模拟实现vector部分功能的代码&#xff0c;可以直接拿去使用 一、头文件 .h文件 #include<assert.h> #include<iostream> using namespace std; namespace zz {template<class T>class vector{public:typedef…

C++ set,multiset与map,multimap的基本使用

1. 序列式容器和关联式容器 string、vector、list、deque、array、forward_list等STL容器统称为序列式容器&#xff0c;因为逻辑结构为线性序列的数据结构&#xff0c;两个位置存储的值之间一般没有紧密的关联关系&#xff0c;比如交换一下&#xff0c;他依旧是序列式容器。顺…

STM32器件支持包安装,STLINK/JLINK驱动安装

一、支持包安装 1、离线安装 先下载支持包之后&#xff0c;再进行安装。如下图要安装STM32F1系列&#xff0c;双击 出现如下&#xff0c;会自动锁定安装路径&#xff0c;然后点击下一步&#xff0c;直接安装。 2、在线安装 首先需要电脑联网。如下。先点击第一个红框绿色按钮…

常见的VPS或者独立服务器的控制面板推荐

随着越来越多的企业和个人转向VPS和独立服务器以获得更高的性能和灵活性&#xff0c;选择合适的控制面板变得尤为重要。一个好的控制面板可以大大简化服务器管理&#xff0c;提高工作效率。本篇文章将介绍2024年最值得推荐的VPS控制面板&#xff0c;帮助您做出明智的选择。 1.…

STL容器适配器

欢迎来到本期节目- - - STL容器适配器 适配器模式&#xff1a; 在C中&#xff0c;适配器是一种设计模式&#xff0c;有时也称包装样式&#xff1b; 通过将类自己的接口包裹在一个已存在的类中&#xff0c;使得因接口不兼容而不能在一起工作的类能在一起工作&#xff1b; 也就…

使用VBA快速生成Excel工作表非连续列图片快照

Excel中示例数据如下图所示。 现在需要拷贝A2:A15,D2:D15,J2:J15,L2:L15,R2:R15为图片&#xff0c;然后粘贴到A18单元格&#xff0c;如下图所示。 大家都知道VBA中Range对象有CopyPicture方法可以拷贝为图片&#xff0c;但是如果Range对象为非连续区域&#xff0c;那么将产生10…

详解DHCP服务工作原理及配置案例

一. DHCP概述 DHCP&#xff08;Dynamic Host Configuration Protocol&#xff0c;动态主机配置协议&#xff09;是一个主机IP简化分配管理的TCP/IP协议&#xff0c;用户通过DHCP服务器动态的分配给客户端IP地址及其他环境的配置工作&#xff0c;包括IP地址、子网掩码、网关和…

【NVIDIA】如何使用nvidia-smi命令管理和监控GPU

博主未授权任何人或组织机构转载博主任何原创文章&#xff0c;感谢各位对原创的支持&#xff01; 博主链接 本人就职于国际知名终端厂商&#xff0c;负责modem芯片研发。 在5G早期负责终端数据业务层、核心网相关的开发工作&#xff0c;目前牵头6G算力网络技术标准研究。 博客…

KPConv: Flexible and Deformable Convolution for Point Clouds

Abstract Kernel Point Convolution&#xff08;KPConv&#xff09;是一种点云卷积方法&#xff0c;它可以直接在点云数据上进行操作&#xff0c;无需任何中间的表示形式。方法的核心在于使用核点来定义卷积权重&#xff0c;核点位于欧几里得空间中&#xff0c;并仅对靠近它们…

Spring DI 笔记

目录 1.什么是DI? 2.依赖注入的三种⽅式 2.1属性注⼊ 2.2构造⽅法注⼊ 2.3Setter 注⼊ 2.4三种注⼊优缺点分析 3.Autowired存在问题 1.什么是DI? DI: 依赖注⼊ 依赖注⼊是⼀个过程&#xff0c;是指IoC容器在创建Bean时, 去提供运⾏时所依赖的资源&#xff0c;⽽资源指的…

(JAVA)浅尝关于 “栈” 数据结构

1. 栈的概述&#xff1a; 1.1 生活中的栈 存储货物或供旅客住宿的地方&#xff0c;可引申为仓库、中转站。例如酒店&#xff0c;在古时候叫客栈&#xff0c;是供旅客休息的地方&#xff0c;旅客可以进客栈休息&#xff0c;休息完毕后就离开客栈 1.2计算机中的栈 将生活中的…