Spring Security 是一个功能强大且高度可定制的身份验证和访问控制框架,其认证和授权实现机制如下:

一、认证(Authentication)实现
1. 核心组件
AuthenticationManager:认证入口点,委托给AuthenticationProvider

AuthenticationProvider:实际执行认证逻辑

UserDetailsService:加载用户特定数据

SecurityContextHolder:存储当前安全上下文

2. 认证流程
用户提交凭证(用户名/密码等)

UsernamePasswordAuthenticationFilter拦截请求,创建Authentication对象

ProviderManager选择合适的AuthenticationProvider

DaoAuthenticationProvider调用UserDetailsService加载用户详情

PasswordEncoder验证密码

认证成功后构建完全填充的Authentication对象

将Authentication存入SecurityContext

3. 常用认证方式

@Configuration
@EnableWebSecurity
public class SecurityConfig extends WebSecurityConfigurerAdapter {

@Override
protected void configure(AuthenticationManagerBuilder auth) throws Exception {
// 内存认证
auth.inMemoryAuthentication()
.withUser("user").password(passwordEncoder().encode("password")).roles("USER");

// JDBC认证
auth.jdbcAuthentication()
.dataSource(dataSource)
.usersByUsernameQuery("select username,password,enabled from users where username=?")
.authoritiesByUsernameQuery("select username,authority from authorities where username=?");

// 自定义UserDetailsService
auth.userDetailsService(customUserDetailsService)
.passwordEncoder(passwordEncoder());
}

@Bean
public PasswordEncoder passwordEncoder() {
return new BCryptPasswordEncoder();
}
}
二、授权(Authorization)实现
1. 核心概念
GrantedAuthority:授予用户的权限(如角色)

ConfigAttribute:访问资源所需的权限

AccessDecisionManager:做出最终的访问控制决策

AccessDecisionVoter:投票决定是否授予访问权限

2. 授权流程
FilterSecurityInterceptor拦截请求

获取请求资源的配置属性(所需权限)

AccessDecisionManager收集投票

基于投票结果允许/拒绝访问

3. 授权配置方式

@Override
protected void configure(HttpSecurity http) throws Exception {
http
.authorizeRequests()
.antMatchers("/admin/**").hasRole("ADMIN") // 基于角色
.antMatchers("/api/**").hasAuthority("API_ACCESS") // 基于权限
.antMatchers("/public/**").permitAll() // 公开访问
.anyRequest().authenticated() // 其他请求需要认证
.and()
.formLogin() // 表单登录
.and()
.httpBasic(); // HTTP基本认证
}
三、高级特性
1. 方法级安全


@PreAuthorize("hasRole('ADMIN') or #user.username == authentication.name")
public void updateUser(User user) {
// ...
}

@PostAuthorize("returnObject.owner == authentication.name")
public Document getDocument(Long id) {
// ...
}

@Secured("ROLE_ADMIN")
public void adminOperation() {
// ...
}
2. 自定义认证逻辑

@Component
public class CustomAuthenticationProvider implements AuthenticationProvider {

    @Autowired
private CustomUserDetailsService userDetailsService;

@Autowired
private PasswordEncoder passwordEncoder;

    @Override
public Authentication authenticate(Authentication authentication) 
throws AuthenticationException {

String username = authentication.getName();
String password = authentication.getCredentials().toString();

CustomUser user = userDetailsService.loadUserByUsername(username);

if (passwordEncoder.matches(password, user.getPassword())) {
return new UsernamePasswordAuthenticationToken(
user, password, user.getAuthorities());
} else {
throw new BadCredentialsException("Authentication failed");
}
}

    @Override
public boolean supports(Class<?> authentication) {
return authentication.equals(UsernamePasswordAuthenticationToken.class);
}
}
3. OAuth2集成


@Configuration
@EnableAuthorizationServer
public class OAuth2Config extends AuthorizationServerConfigurerAdapter {

@Override
public void configure(ClientDetailsServiceConfigurer clients) throws Exception {
clients.inMemory()
.withClient("client")
.secret(passwordEncoder.encode("secret"))
.authorizedGrantTypes("authorization_code", "refresh_token")
.scopes("read", "write")
.redirectUris("http://localhost:8080/login/oauth2/code/custom");
}
}
四、实际应用建议
密码安全:始终使用强密码编码器(如BCrypt)

CSRF防护:生产环境必须启用

会话管理:合理配置会话固定保护和并发控制

CORS配置:根据实际需求精细控制

安全头部:启用XSS保护、HSTS等安全头部

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

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

相关文章

开源的时间跟踪工具TimeTagger

简介 什么是 TimeTagger &#xff1f; TimeTagger 是一个开源的时间跟踪工具&#xff0c;旨在帮助用户记录和分析他们的时间使用情况。它提供了一个互动的用户界面和强大的报告功能&#xff0c;适合个人和自由职业者使用。 主要特点 直观的用户界面&#xff1a;基于互动时间线…

学习游戏制作记录(角色属性和状态脚本)8.4

1.实现简单的角色属性创建CharactorState脚本&#xff1a;挂载在敌人和玩家身上public float damage;//角色伤害public float maxHp;//最大生命[SerializeField] private float currentHealth;//当前生命void Start(){currentHealth maxHp;//初始化将当前生命设置为最大生命}p…

04-Chapter02-Example01

文章介绍 1、完善项目结构 1.1 新建第二章对应模块Chapter021.2 新建模块Chapter02对应包com.itheima1.3 在包com.itheima下新建class类 &#xff0c;类名称Example01.java项目结构如下&#xff1a;2、编写Example01.java代码 P38 package com.itheima;public class Example01…

【达梦MPP(带主备)集群搭建】

达梦MPP&#xff08;带主备&#xff09;集群搭建 为了提高MPP系统可靠性&#xff0c;克服由于单节点故障导致整个系统不能继续正常工作的问题&#xff0c;DM在普通的MPP系统基础上&#xff0c;引入数据守护主备机制&#xff0c;为每一个MPP节点配置一个实时备库作为备份节点&a…

Java基础学习(一):类名规范、返回值、注释、数据类型

目录 一、类名规范二、返回值三、注释四、数据类型 1. 基本类型2. 引用类型3. 强制数据类型转换4. 进制5. 进制的转换6. 超范围运算 相关文章 Java基础学习&#xff08;二&#xff09;&#xff1a;Java中的变量和常量、final&#xff08;重点&#xff09;、运算、字符串 了…

Nginx相关实验(2)

nginx的一些高级配置 nginx状态页 基于nginx 模块 ngx_http_stub_status_module 实现&#xff0c; 在编译安装nginx的时候需要添加编译参数 --with-http_stub_status_module 否则配置完成之后监测会是提示语法错误 #检查模块是否配置 如果不存在需要添加模块重新编译 nginx …

2.Java和C++有什么区别

2.Java和C有什么区别 1.在C中&#xff0c;支持操作符重载&#xff0c;而在Java里是不允许的 2.C支持多继承&#xff0c;而Java不可以&#xff0c;但Java可以单继承多实现 3.Java内置多线程机制&#xff0c;而C没有 4.Java里面自带了垃圾回收机制&#xff0c;可以自动清理缓存等…

MLIR Introduction

简介 MLIR 项目是一个构建可重用和可扩展编译器基础设施创新项目&#xff0c;旨在解决软件碎片化问题&#xff0c;显著降低构建特定领域编译器的成本。 基于MLIR&#xff0c;可以实现&#xff1a; 数据流图表达&#xff08;如TensorFlow&#xff09;&#xff0c;包含dynamic…

[找出字符串中第一个匹配项的下标]

代码思路分析&#xff1a; 1. 边界情况处理 代码中没有显式处理以下边界情况&#xff0c;但逻辑已隐含支持&#xff1a; needle 为空字符串&#xff1a;应返回 0&#xff08;但题目通常保证 needle 非空&#xff09;。haystack 比 needle 短&#xff1a;直接返回 -1&#xff08…

深入剖析RT-Thread串口驱动:基于STM32H750的FinSH Shell全链路Trace分析与实战解密(上)

0. 概述 这是cherryusb代码trace分析系列文章之七。 RT-Thread串口驱动框架与FinSH Shell运行机制深度解析&#xff1a;针对STM32H750 ART-PI平台&#xff0c;本文独辟蹊径采用创新的代码trace分析方法&#xff0c;破解庞大串口框架下的复杂运行逻辑。通过精确trace日志与drv_u…

Python与C++通信教程:C++打包dll,供Python调用(1)

目录 1,新建一个工程 math_functions.cpp内容: 先编译一下看是否可以正常运行: 2,编译成dll,并用Python调用 有两种方式: 命令 1(使用静态链接): 可移植性: 命令 2(动态链接): 可移植性: 这里我使用的是静态链接的方式: python调用实例 test_dll.py 1,…

编程与数学 03-002 计算机网络 19_网络新技术研究

编程与数学 03-002 计算机网络 19_网络新技术研究一、软件定义网络&#xff08;SDN&#xff09;&#xff08;一&#xff09;SDN的基本原理与架构&#xff08;二&#xff09;SDN的应用场景与优势二、网络功能虚拟化&#xff08;NFV&#xff09;&#xff08;一&#xff09;NFV的概…

uniapp 跨端开发

一、创建uniapp项目 1. 项目架构2. 初始化项目3. pages.json 和 tabBar 案例4. uni-app和原生小程序开发区别5. 用命令行创建uni-app项目 官网链接&#xff1a;https://uniapp.dcloud.net.cn/quickstart-cli.html#创建uni-app6. 用vscode开发uni-app在uni-app中只有manifest.js…

区块链支付技术的核心原理

区块链支付利用分布式账本技术&#xff08;DLT&#xff09;实现点对点的价值转移&#xff0c;无需传统银行或支付网关的中介。核心特点是去中心化、透明、可追溯。• 基本流程&#xff1a;1. 用户发起交易&#xff1a;通过加密货币钱包发送支付请求&#xff08;例如用ETH支付&a…

linux中 多进程 导致cuda错误的问题解决

问题总结与解决方案 核心问题 在使用 Linux 系统时&#xff0c;多进程并行计算中加载模型到 GPU 时出现错误&#xff1a;_MODEL SentenceTransformer( model_path, device "cuda" if torch.cuda.is_available() else "cpu" )根本原因&#xff1a; CUDA 上…

智能感知的新入口:AIGC 与低延迟视频通路的深度融合

✳️ 引言&#xff1a;AIGC&#xff0c;正在重构视觉智能的“生成逻辑” AI生成内容&#xff08;AIGC&#xff09;正在从“内容创作工具”跃升为计算机视觉系统的新引擎。它不再只是“文生图”、“图生文”的演示技术&#xff0c;而是实实在在地改变着我们构建、处理和理解视觉…

Ubuntu 内网多台服务器时间同步方案(适用于临时能上外网的环境)

哎&#xff0c;最近项目是运行在内网环境下的&#xff0c;出现了由于时间不同步导致的bug。一般来讲&#xff0c;几台服务器的时间不一致&#xff0c;会带来很多问题&#xff0c;比如日志时间对不上、分布式服务出现异常&#xff0c;等等。项目上现在有三台服务器&#xff0c;其…

延长电池寿命的低Iq技术

本文章是笔者整理的备忘笔记。希望在帮助自己温习避免遗忘的同时&#xff0c;也能帮助其他需要参考的朋友。如有谬误&#xff0c;欢迎大家进行指正。一、概述随着电池供电型应用的激增&#xff0c;人们对质优价廉的电池和电池包的需求持续猛涨。电池制造商们不断采用新的化学物…

QT 如何实现enum与字符串的互转

将enum中定义的枚举值&#xff0c;以字符串的形式写入文件&#xff0c;同时也能从字符串转为枚举值。举例说明&#xff1a; ColorSelector中的Colors枚举&#xff0c;我们希望 kColorRed 这个写入到本地文件时&#xff0c;可以直接保存“kColorRed”&#xff0c;而非kColorRed对…

SLAM卷不动了,机器人还有哪些方向能做?

关注gongzhonghao【CVPR顶会精选】众所周知&#xff0c;机器人因复杂环境适应性差、硬件部署成本高&#xff0c;对高效泛化一直需求迫切。再加上多传感器协同难题、真实场景数据获取不易&#xff0c;当下对迁移学习 机器人智能融合的研究也就更热烈了。不过显然&#xff0c;这…