SpringBoot开发——Spring Security中获取当前登录用户信息的方式

文章目录

  • 1、前言
  • 2、实现方法
    • 2.1 使用Authentication对象获取当前登录用户信息
    • 2.2 使用SecurityContextHolder获取当前登录用户信息

1、前言

Web应用程序开发中,用户认证与授权是确保系统安全性的关键环节。Spring Security作为Spring框架的一部分,提供了一个强大且灵活的身份认证和授权框架,广泛应用于Java企业级应用中。它不仅简化了应用程序的安全性管理,还通过提供全面的安全性解决方案,帮助开发者有效防止各种安全威胁,如跨站请求伪造(CSRF)、会话固定攻击等。

Spring Security中,获取当前登录用户的详细信息是常见的需求之一。这些信息对于实现个性化用户界面、日志记录、权限控制等至关重要。Spring Security通过其核心的Authentication对象SecurityContextHolder类,为开发者提供了便捷的方式来访问当前登录用户的详细信息。

2、实现方法

2.1 使用Authentication对象获取当前登录用户信息

Spring Security的架构中,用户访问受保护的资源前必须通过身份验证流程。一旦用户成功通过身份验证,Spring Security会将用户的认证信息封装在一个名为Authentication的对象中。这个Authentication对象不仅包含了用户的身份标识(如用户名),还可能包含用户的权限、角色等详细信息。因此,当需要获取当前登录用户的详细信息时,我们可以通过Spring Security提供的机制来访问当前上下文中的Authentication对象,进而获取到用户的认证信息及其附加的详细信息。

@Controller
public class UserController {@GetMapping("/user")public String getCurrentUser(Authentication authentication) {UserDetails userDetails = (UserDetails) authentication.getPrincipal();String username = userDetails.getUsername();Collection<? extends GrantedAuthority> authorities = userDetails.getAuthorities();// 这里可以根据需要获取更多的用户信息return "用户名:" + username + ";角色:" + authorities;}
}

2.2 使用SecurityContextHolder获取当前登录用户信息

为了通过Authentication对象获取当前登录用户的信息,Spring Security设计了一个名为SecurityContextHolder的类。这个类允许从应用程序的任何地方访问当前请求的SecurityContext,而SecurityContext中则包含了已经通过身份验证的用户的Authentication信息。通过SecurityContextHolder,我们可以轻松地获取到当前登录用户的Authentication对象,进而访问用户的详细信息,如用户名、权限、角色等。这种设计使得在Spring Security保护的应用程序中,用户信息的获取变得既方便又安全。

@Controller
public class UserController {@GetMapping("/user")public String getCurrentUser() {Authentication authentication = SecurityContextHolder.getContext().getAuthentication();UserDetails userDetails = (UserDetails) authentication.getPrincipal();String username = userDetails.getUsername();Collection<? extends GrantedAuthority> authorities = userDetails.getAuthorities();// 这里可以根据需要获取更多的用户信息return "用户名:" + username + ";角色:" + authorities;}
}

使用SecurityContextHolder.getContext().getAuthentication()方法,我们可以从Spring Security的上下文中检索到当前的Authentication对象。这个对象代表了当前通过身份验证的用户,并包含了用户的详细信息,如用户名、权限集等,使我们能够根据需要进一步获取用户的更多信息。

然而,重要的是要强调,SecurityContextHolder的设计允许在应用程序的任何地方读取或更改当前的SecurityContext(及其包含的Authentication对象)。虽然这种灵活性在某些情况下可能非常有用,但它也要求开发者在使用SecurityContextHolder时保持极高的谨慎性。不恰当的修改可能会导致安全漏洞、会话管理问题或数据不一致,因此必须确保所有对SecurityContext的修改都是必要且安全的。

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

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

相关文章

5. 常用开源数据集快速导入Linux服务器(AutoDL)——深度学习·科研实践·从0到1

目录 1. 查找公开数据 2. 解压到自己的数据盘中 3. 解压常用指令 1. 查找公开数据 参考文档&#xff1a;AutoDL帮助文档-公开数据查找和导入 AutoDL提供了部分常用开源数据&#xff0c;供咱在实例中进行使用&#xff0c;免去下载上传的烦恼&#xff08;直接解压到咱的服务…

OpenAi FunctionCalling 案例详解

源码详细讲解 pdf 及教学视频下载链接&#xff1a;点击这里下载 FunctionCalling的单一函数调用 天气预报查询&#xff08;今天长沙的天气如何&#xff1f;&#xff09; import json import requests from openai import OpenAIclient OpenAI()location "长沙"…

鸿蒙开发知识点速记全解

入门 1、API涵盖应用框架、系统、媒体、图形、应用服务、AI六大领域。 应用框架相关Kit开放能力&#xff1a;Ability Kit&#xff08;程序框架服务&#xff09;、ArkUI&#xff08;方舟UI框架&#xff09;等。系统相关Kit开放能力&#xff1a;Universal Keystore Kit&#xf…

24-10-1-读书笔记(二十一)-《契诃夫文集》(四)下([俄] 契诃夫 [译] 汝龙) 我爱你,娜坚卡。

文章目录 《契诃夫文集》&#xff08;四&#xff09;下&#xff08;[俄] 契诃夫 [译] 汝龙 &#xff09;目录阅读笔记记录总结 《契诃夫文集》&#xff08;四&#xff09;下&#xff08;[俄] 契诃夫 [译] 汝龙 &#xff09; 十月第一篇&#xff0c;放假了&#xff0c;挺高兴的&…

四、I/O控制方式

1.程序直接控制方式 完成一次读/写的过程 CPU千预频率 每次I/O的数据传输单位 数据流向 优缺点 CPU发出I/0命令后需要不断轮询 极高 字 设备→CPU→内存 内存→CPU→设备 优点:实现简单。在读/写指令之后&#xff0c;加上实现循环检查的一系列指令即可(因此才称为“程…

WaterCloud:一套基于.NET 8.0 + LayUI的快速开发框架,完全开源免费!

前言 今天大姚给大家分享一套基于.NET 8.0 LayUI的快速开发框架&#xff0c;项目完全开源、免费&#xff08;MIT License&#xff09;且开箱即用&#xff1a;WaterCloud。 可完全实现二次开发让开发更多关注业务逻辑。既能快速提高开发效率&#xff0c;帮助公司节省人力成本&…

Stable Diffusion绘画 | 来训练属于自己的模型:打标处理与优化

上一篇完成的打标工作&#xff0c;是为了获取提示词&#xff0c;让AI认识和学习图片的特征。 因此&#xff0c;合适、恰当、无误的提示词&#xff0c;对最终模型效果是相当重要的。 Tag 如何优化 通过软件自动生成的 Tag 只是起到快速建立大体架构的作用&#xff0c;里面会涉…

某大型公园定岗定编项目成功案例纪实

某大型公园定岗定编项目成功案例纪实 ——优化人力配置&#xff0c;实施灵活化人员调整策略&#xff0c;解决忙闲不均问题 【客户行业】文旅行业&#xff1b;事业单位&#xff1b;公园 【问题类型】定岗定编 【客户背景】 某大型公园随着上级政策的改变&#xff0c;公园取…

探索 PixiJS:强大的 2D 图形渲染库

探索 PixiJS&#xff1a;强大的 2D 图形渲染库 演示地址 演示地址 源码地址 源码地址 获取更多 获取更多 随着 Web 技术的发展&#xff0c;越来越多的开发者希望在网页中实现丰富的视觉效果和动画。PixiJS 作为一个高性能的 2D 渲染库&#xff0c;凭借其强大的功能和易用性…

文件名:\\?\C:\Windows\system32\inetsrv\config\applicationHost.config错误:无法写入配置文件

文件名: \\?\C:\Windows\system32\inetsrv\config\applicationHost.config 错误:无法写入配置文件 解决办法&#xff1a; 到C:\inetpub\history中找到最近一次的【CFGHISTORY_00000000XX】文件&#xff0c;点击进去找到applicationHost.config文件&#xff0c;用其覆盖C:\Win…

C++ 游戏开发

C游戏开发 C 是一种高效、灵活且功能强大的编程语言&#xff0c;因其性能和控制能力而在游戏开发中被广泛应用。许多著名的游戏引擎&#xff0c;如 Unreal Engine、CryEngine 和 Godot 等&#xff0c;都依赖于 C 进行核心开发。本文将详细介绍 C 在游戏开发中的应用&#xff0…

B. Brightness Begins Codeforces Round 976 (Div. 2)

原题 B. Brightness Begins 解析 Hint 1 第 i 个灯泡最终状态与 n 的大小无关 Hint 2 第 i 个灯泡最终状态与 i 的约数数量的奇偶性相关 Solution 对任意灯泡 i , 它的最终状态由其约数数量的奇偶性相关, 如果 i 有偶数个约数, 那么会是亮的, 否则会是暗的. 换句话说, 如…

使用Materialize制作unity的贴图,Materialize的简单教程,Materialize学习日志

Materialize 官网下载地址&#xff1a;http://boundingboxsoftware.com/materialize/ github源码地址&#xff1a;https://github.com/BoundingBoxSoftware/Materialize 下载地址&#xff1a;http://boundingboxsoftware.com/materialize/getkey.php 下载后解压运行exe即可 …

安装epic games错误码2738解决(安装ue错误码2738)

这个错误不好找到解决方案&#xff0c;尝试删除注册表以及通过电脑管家下载安装都不生效&#xff0c;仍然会错误2738。直到找到了这个解决方案。 1.cmd然后右键以管理员身份运行&#xff0c; 2.cd %windir%\syswow64进入该目录 3.reg delete “HKCU\SOFTWARE\Classes\Wow6432No…

C语言 | Leetcode C语言题解之题451题根据字符出现频率排序

题目&#xff1a; 题解&#xff1a; #define HASH_FIND_CHAR(head, findint, out) HASH_FIND(hh, head, findint, sizeof(char), out) #define HASH_ADD_CHAR(head, intfield, add) HASH_ADD(hh, head, intfield, sizeof(char), add)struct HashTable {char key;int val;UT_ha…

【STM32单片机_(HAL库)】4-4【定时器TIM】脉冲计数配置步骤及实验

脉冲计数配置步骤 1.硬件 STM32单片机最小系统按键模块 2.软件 定时器HAL驱动层文件添加counter驱动文件添加GPIO常用函数main.c程序 #include "sys.h" #include "delay.h" #include "led.h" #include "uart1.h" #include "…

6.3 API网关 架构模式 分类 和 应用实践

6.3 API网关 架构模式 分类 和 应用实践 目录概述需求&#xff1a; 设计思路实现思路分析1.反向代理模式2.微服务模式3.单体模式4.服务网格模式 分类&#xff1a;1.2.1 按功能分类3.2.2 按部署方式分类4.2.3 按协议支持分类&#xff1a; 应用实践&#xff1a; 参考资料和推荐阅…

Windows 开发工具使用技巧 QT使用安装和使用技巧 QT快捷键

一、QT配置 1. 安装 Qt 开发框架 1、下载 1、进入下载地址 下载地址1 (官方, 需注册账号)&#xff1a; https://www.qt.io/download下载地址2&#xff08;推荐&#xff09;&#xff1a; http://download.qt.io/http://download.qt.io/archive/qt/ &#xff08;或更直接的…

植物叶片病害检测数据集 5100张 29类 带标注 voc yolo

植物叶片病害检测数据集 5100张 29类 带标注 voc yolo 植物叶片病害检测数据集 名称 植物叶片病害检测数据集 (Plant Leaf Disease Detection Dataset) 规模 图像数量&#xff1a;5154张图像。类别&#xff1a;29种病害类型。分类名: (图片张数&#xff0c;标注个数) Tomato…

【CSS3】css开篇基础(1)

1.❤️❤️前言~&#x1f973;&#x1f389;&#x1f389;&#x1f389; Hello, Hello~ 亲爱的朋友们&#x1f44b;&#x1f44b;&#xff0c;这里是E绵绵呀✍️✍️。 如果你喜欢这篇文章&#xff0c;请别吝啬你的点赞❤️❤️和收藏&#x1f4d6;&#x1f4d6;。如果你对我的…