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

从配置文件到配置类:Spring Boot Security 的权限控制演进

1. Spring Security 的配置文件时代记得我第一次用 Spring Security 是在五年前的一个内部管理系统项目上。当时为了快速上线直接在 application.yml 里写死了用户名密码就像这样spring: security: user: name: admin password: 123456 roles: ADMIN这种配置方式简单粗暴到什么程度呢你甚至不需要写任何 Java 代码只要引入了 spring-boot-starter-security 依赖系统就会自动弹出一个默认登录页。我当年就是被这种开箱即用的特性惊艳到了但很快就在实际项目中碰了钉子。内存用户的局限性在真实场景中会立刻暴露密码明文存储连 base64 编码都没有用户信息硬编码在配置文件里每次修改用户都要重启服务角色权限是写死的字符串更麻烦的是 URL 权限控制。比如你想让/api/public允许匿名访问/api/admin需要管理员权限在纯配置文件中几乎无法实现。这时候就得请出 WebSecurityConfigurerAdapter 这个老朋友了。2. 配置类真正的生产级方案2.1 基础配置类搭建先看一个典型的 SecurityConfig 骨架Configuration EnableWebSecurity public class SecurityConfig extends WebSecurityConfigurerAdapter { Override protected void configure(HttpSecurity http) throws Exception { http.authorizeRequests() .antMatchers(/public/**).permitAll() .antMatchers(/admin/**).hasRole(ADMIN) .anyRequest().authenticated() .and() .formLogin(); } }这个配置类做了三件大事开放/public路径的匿名访问限制/admin路径仅限 ADMIN 角色访问其他所有请求都需要登录关键进化点在于权限规则可编程化能用 if-else 逻辑支持方法级注解控制后面会讲可以集成数据库用户体系2.2 用户认证的三种姿势配置类最大的优势是能灵活定义用户来源。我整理过三种常见方案方案适用场景示例代码片段内存用户测试环境auth.inMemoryAuthentication()JDBC 认证中小型生产系统auth.jdbcAuthentication()自定义 UserDetails复杂权限系统auth.userDetailsService()最推荐的是第三种自定义实现。比如对接公司 LDAP 或自定义权限表时Override protected void configure(AuthenticationManagerBuilder auth) throws Exception { auth.userDetailsService(myUserService) .passwordEncoder(bCryptPasswordEncoder()); }3. 方法级权限控制实战URL 级别的控制还不够精细试试方法注解PreAuthorize(hasRole(ADMIN) or #userId authentication.name) public User getUserProfile(String userId) { // 仅管理员或用户本人可访问 }注解三剑客的适用场景PreAuthorize方法执行前校验最常用PostAuthorize方法执行后校验较少用Secured简单角色校验Spring 原生注解特别注意要启用这些注解必须在配置类加上EnableGlobalMethodSecurity( prePostEnabled true, // 开启Pre/Post注解 securedEnabled true // 开启Secured )4. 现代 Spring Security 的最佳实践最近两年 Spring Security 又有新变化。比如 WebSecurityConfigurerAdapter 已经被标记为过时推荐使用组件式配置Bean SecurityFilterChain securityFilterChain(HttpSecurity http) throws Exception { return http .authorizeHttpRequests(auth - auth .requestMatchers(/public/**).permitAll() .anyRequest().authenticated() ) .formLogin(withDefaults()) .build(); }新旧版本对比表特性旧版 (5.7)新版 (6.0)配置方式继承抽象类组件式 Bean请求匹配antMatchersrequestMatchers密码编码器需要显式配置强制要求加密CSRF 防护默认开启默认关闭升级时最容易踩的坑是密码编码器。新版强制要求必须配置推荐使用Bean PasswordEncoder passwordEncoder() { return PasswordEncoderFactories.createDelegatingPasswordEncoder(); }在实际项目中我通常会额外配置这些安全防护会话固定保护session fixation点击劫持防护X-Frame-Options内容安全策略CSP 头部安全请求头HSTS 等这些配置现在都可以通过 lambda DSL 流畅地表达http.securityContext(context - context .requireExplicitSave(false)) .headers(headers - headers .frameOptions().sameOrigin() .contentSecurityPolicy(csp - csp .policyDirectives(default-src self))) .csrf(csrf - csrf.ignoringRequestMatchers(/api/**));从配置文件到配置类再到现在的组件式配置Spring Security 的演进始终围绕着两个核心目标安全性的强化和开发体验的优化。每次升级都意味着更少的样板代码和更精确的安全控制这才是框架设计的艺术。

相关文章:

从配置文件到配置类:Spring Boot Security 的权限控制演进

1. Spring Security 的配置文件时代 记得我第一次用 Spring Security 是在五年前的一个内部管理系统项目上。当时为了快速上线,直接在 application.yml 里写死了用户名密码,就像这样: spring:security:user:name: adminpassword: 123456roles…...

3个关键步骤实现FanControl中文界面完美配置

3个关键步骤实现FanControl中文界面完美配置 【免费下载链接】FanControl.Releases This is the release repository for Fan Control, a highly customizable fan controlling software for Windows. 项目地址: https://gitcode.com/GitHub_Trending/fa/FanControl.Releases…...

Linux小白看过来:手把手教你用命令行在Ubuntu 16.04搞定MATLAB 2021b

Linux命令行实战:Ubuntu 16.04安装MATLAB 2021b全指南 第一次在Linux系统上安装专业软件?别担心,命令行操作其实比图形界面更高效。本文将带你用终端命令完成MATLAB 2021b的完整安装过程,每个步骤都会解释背后的原理,让…...

Matlab散点图进阶:scatter函数参数详解与实战代码解析

1. scatter函数基础:从零开始绘制散点图 第一次接触Matlab的scatter函数时,我被它强大的定制能力惊艳到了。这个看似简单的绘图工具,实际上藏着无数让数据可视化的魔法。让我们从一个最基本的例子开始: x randn(100,1); % 生成1…...

药品说明书查询系统源码 本地数据库 PHP版本

内容目录一、详细介绍二、效果展示1.部分代码2.效果图展示一、详细介绍 药品说明书查询系统源码 本地数据库 PHP版本 使用的是大佬YMXuan的数据库,数据库大小442MB PHP版本7.0以上即可,兼容手机端显示查询。 使用方法:将数据库文件drugs.db 和PHP文件…...

国产小参数大模型落地实践:南北阁 Nanbeige 4.1-3B 在中小企业AI助手场景应用

国产小参数大模型落地实践:南北阁 Nanbeige 4.1-3B 在中小企业AI助手场景应用 1. 引言:为什么中小企业需要自己的AI助手? 想象一下,你的公司每天要处理大量的客户咨询、内部文档整理和会议纪要。如果有一个能理解你业务、随时待…...

BK3633 Keil 工程中自动化构建与版本管理的进阶配置指南

1. 为什么需要自动化构建与版本管理 在嵌入式开发中,每次手动编译、打包、命名固件都是件费时费力的事情。特别是像BK3633这样的蓝牙芯片项目,往往需要同时维护Debug和Release两个版本。Debug版本用于开发调试,需要保留日志输出和调试信息&am…...

如何快速上手Citra模拟器:3步完成3DS游戏体验的终极指南

如何快速上手Citra模拟器:3步完成3DS游戏体验的终极指南 【免费下载链接】citra A Nintendo 3DS Emulator 项目地址: https://gitcode.com/GitHub_Trending/ci/citra Citra是一款开源的任天堂3DS模拟器,让你能在PC上畅玩经典的3DS游戏。无论你是想…...

rPPG非接触式心率检测框架:从零开始构建你的远程生理监测系统

rPPG非接触式心率检测框架:从零开始构建你的远程生理监测系统 【免费下载链接】rppg Benchmark Framework for fair evaluation of rPPG 项目地址: https://gitcode.com/gh_mirrors/rpp/rppg 在当今数字健康时代,rPPG(远程光电容积描记…...

DXF服务端部署实战:从环境配置到异常排查的完整指南

1. 环境准备:从零搭建DXF服务端的基石 第一次部署DXF服务端的朋友们,千万别急着跑起来就完事。我见过太多人卡在环境配置这一步,折腾半天才发现是基础依赖没装全。咱们先从最底层的系统环境说起,这里我用的是CentOS 7.x系统&#…...

PPTAgent:3分钟用AI生成专业演示文稿,告别繁琐的手工制作

PPTAgent:3分钟用AI生成专业演示文稿,告别繁琐的手工制作 【免费下载链接】PPTAgent An Agentic Framework for Reflective PowerPoint Generation 项目地址: https://gitcode.com/gh_mirrors/pp/PPTAgent 你是否曾为制作演示文稿而烦恼&#xff…...

Nacos点击下线报错「主节点不存在」解决方案

在日常微服务开发和运维中,Nacos作为常用的服务注册与配置中心,偶尔会遇到各类异常问题。今天就给大家分享一个实际项目中遇到的高频报错——点击服务下线时,弹出「主节点不存在」提示,结合问题排查过程和官方文档,整理…...

旧本焕新记:华硕A555L低成本改造实战与取舍

1. 老旧笔记本改造的价值评估 拿到这台华硕A555L的第一件事,就是评估它是否值得改造。这台2015年上市的笔记本,配置确实有些年头了:i5-5200U处理器、4GB内存、500GB混合硬盘,再加上入门级的NVIDIA 930M显卡。说实话,现…...

Windows Cleaner:彻底解决C盘空间不足的终极指南

Windows Cleaner:彻底解决C盘空间不足的终极指南 【免费下载链接】WindowsCleaner Windows Cleaner——专治C盘爆红及各种不服! 项目地址: https://gitcode.com/gh_mirrors/wi/WindowsCleaner 你的Windows电脑是不是经常出现C盘爆红的警告&#x…...

如何彻底告别AutoCAD字体缺失烦恼?FontCenter终极解决方案完整指南

如何彻底告别AutoCAD字体缺失烦恼?FontCenter终极解决方案完整指南 【免费下载链接】FontCenter AutoCAD自动管理字体插件 项目地址: https://gitcode.com/gh_mirrors/fo/FontCenter 你是否曾经在打开同事发来的CAD图纸时,看到满屏的问号和乱码&a…...

英雄联盟智能助手LeagueAkari:3个核心功能解决游戏痛点

英雄联盟智能助手LeagueAkari:3个核心功能解决游戏痛点 【免费下载链接】League-Toolkit An all-in-one toolkit for LeagueClient. Gathering power 🚀. 项目地址: https://gitcode.com/gh_mirrors/le/League-Toolkit 在英雄联盟的对局过程中&am…...

算法训练营第六天|反转链表

题目链接: https://leetcode.cn/problems/reverse-linked-list/ 视频链接:https://www.bilibili.com/video/BV1nB4y1i7eL 难点:迭代中如何防止断链以及递归如何实现反转 感想:写的时候容…...

ISP-全链路数据流预览-000005

全链路数据流预览 视频数据从传感器到播放器的完整流转路径,一图掌握核心技术链路V4L2 框架与硬件组件的关系RGB 数据容量远远大于 YUV 数据容量,所以需要转成 YUV MIPI CSI ** **...

自己的规划

各位朋友们大家好呀,初来博客报到,还请大家多多关照~我目前是一名在读研一学生,最近正全身心投入到编程知识的学习中。从基础语法到项目实践,每一步都在认真摸索和积累。我的目标不只是简单学会,而是真正吃…...

Ubuntu服务器环境下的Graphormer生产级部署全攻略

Ubuntu服务器环境下的Graphormer生产级部署全攻略 1. 前言:为什么选择Graphormer? Graphormer是微软研究院推出的基于Transformer架构的图神经网络模型,在分子性质预测、社交网络分析等图结构数据任务上表现出色。与传统的GNN模型相比&…...

Android WebView 中 React useState 更新失效问题

1. 问题 在 Android App 内嵌的 H5 页面(React)中: 打开文件选择器上传图片后,页面所有 useState 的更新(如 setLoading、setRecordList)都不生效接口返回数据正常,但页面不渲染原生 DOM 操作正…...

AI技术带来的SEO关键词优化新方向与应用探索

AI技术的快速发展正在为SEO关键词优化带来全新思维。通过智能化的数据处理和分析,营销人员能够获取到精准的关键词推荐,这使得选择高效关键词变得更加灵活与高效。在此基础上,AI还能够实时监测用户行为变化和市场动态,动态调整关键…...

从物理层到协议栈:详解基于 OTL4 的 ECU 报文唤醒测试全流程

一、 为什么你的控制器“睡不着”?在车载 ECU 开发中,休眠与唤醒(Sleep & Wake-up)是功耗管理的核心。工程师们最头疼的莫过于:1.偶发性唤醒: 停在车库里的车,一夜之间电瓶没电了&#xff0…...

深入解析安路科技PH1系列FPGA的ERAM架构:从BRAM到高效存储方案

1. PH1系列FPGA的ERAM架构概览 第一次拿到安路科技PH1系列FPGA开发板时,我就被它的ERAM(嵌入式随机存取存储器)设计惊艳到了。相比传统FPGA的BRAM(块随机存取存储器),PH1的ERAM在架构上做了很多创新。每个E…...

gym-pybullet-drones终极指南:用Python构建专业的无人机强化学习环境

gym-pybullet-drones终极指南:用Python构建专业的无人机强化学习环境 【免费下载链接】gym-pybullet-drones PyBullet Gymnasium environments for single and multi-agent reinforcement learning of quadcopter control 项目地址: https://gitcode.com/gh_mirro…...

WebSocket长连接优化:宠友IM源码中的心跳与断线重连机制

IM系统上线之后,最容易被忽略的一类问题不是发送失败,而是“看起来在线,实际上已经断了”。这种情况用户感知很直接:消息发不出去、收不到、需要反复重启应用。 宠友信息在「宠友IM」源码里,对WebSocket连接这一层做了…...

避坑指南:STM32与LD3320语音模块串口通信的3个常见问题与解决方案

STM32与LD3320语音模块串口通信实战避坑指南 1. 硬件连接与初始化配置 第一次接触STM32与LD3320语音模块的串口通信时,硬件连接看似简单却暗藏玄机。不少开发者按照常规思路连接后,发现模块毫无反应,这时候往往需要从最基础的硬件配置开始排查…...

D3KeyHelper暗黑3宏工具:游戏自动化终极指南与高效战斗秘籍

D3KeyHelper暗黑3宏工具:游戏自动化终极指南与高效战斗秘籍 【免费下载链接】D3keyHelper D3KeyHelper是一个有图形界面,可自定义配置的暗黑3鼠标宏工具。 项目地址: https://gitcode.com/gh_mirrors/d3/D3keyHelper 想要在暗黑破坏神3中实现技能…...

告别错过直播的烦恼:LiveAutoRecord 直播自动录制完全指南

告别错过直播的烦恼:LiveAutoRecord 直播自动录制完全指南 【免费下载链接】LiveAutoRecord 基于 Electron 的多平台直播自动录制软件 项目地址: https://gitcode.com/GitHub_Trending/li/LiveAutoRecord 你是否曾经因为工作忙碌而错过心爱主播的精彩直播&am…...

题目一: 准备生日礼物 100分

限制:1s 空间限制:256MB 限定语言:C(clang11), C(clang11).Java(javac 1.8), Python3(3.9), JavaScript Node(12.18.2), Go(1.14.4), Rust(1.44) 题目描述:小明在一个充满人文关怀的公司上班,公司每个月都要为该月生日…...