SpringSecurity用户认证授权教程
时间:2025-11-11 23:40:54 306浏览 收藏
**Spring Security 实现用户认证授权教程:快速入门与实战指南** Spring Security 是 Java Web 应用安全领域的主流框架,本文将引导你快速掌握 Spring Security 的核心用法,实现用户登录认证和接口权限控制。首先,通过引入 `spring-boot-starter-security` 依赖,让所有接口默认受到保护。然后,配置 `SecurityConfig` 类,利用 `permitAll()`、`hasRole()` 等方法定义公开接口和角色权限,并启用 `formLogin` 和 `httpBasic` 认证。接着,通过实现 `UserDetailsService` 接口,自定义用户认证逻辑,从数据库加载用户信息并构建 `UserDetails` 对象。最后,使用 `BCryptPasswordEncoder` 对用户密码进行加密存储,保障数据安全。本文还介绍了角色前缀 `ROLE_` 的匹配规则,以及如何利用内置登录页快速验证,并为后续集成 JWT 实现无状态认证打下基础。
首先引入Spring Security依赖,然后通过SecurityConfig配置安全策略,接着实现UserDetailsService加载用户信息,并配置BCrypt密码编码器。具体为:添加spring-boot-starter-security依赖后,所有接口默认受保护;在SecurityConfig中定义permitAll允许公开访问路径,hasRole限制ADMIN接口访问,启用formLogin和httpBasic认证方式;CustomUserDetailsService从数据库加载用户并构建UserDetails对象;使用BCryptPasswordEncoder确保密码加密存储。角色需注意默认的ROLE_前缀匹配规则。初期可使用内置登录页验证流程,后续可集成JWT实现无状态认证。

Spring Security 是 Java 后端开发中实现用户认证和授权的主流框架,能有效保护 Web 应用的安全。要使用它实现基本的用户登录认证和接口权限控制,核心步骤包括引入依赖、配置安全策略、定义用户详情服务以及设置角色权限。
添加 Spring Security 依赖
在基于 Spring Boot 的项目中,只需在 pom.xml 中加入以下依赖:
引入后,所有接口默认会被保护,访问时需要登录。
配置 SecurityConfig 类
创建一个配置类继承 WebSecurityConfigurerAdapter(旧版本)或直接使用新式组件方式(Spring Security 5.7+ 推荐),以下是较新的函数式配置示例:
@Configuration@EnableWebSecurity
public class SecurityConfig {
@Bean
public SecurityFilterChain filterChain(HttpSecurity http) throws Exception {
http
.authorizeHttpRequests(auth -> auth
.requestMatchers("/api/public/**").permitAll()
.requestMatchers("/api/admin/**").hasRole("ADMIN")
.anyRequest().authenticated()
)
.formLogin(withDefaults())
.httpBasic(withDefaults());
return http.build();
}
}
说明:
- permitAll():允许所有人访问公开接口
- hasRole("ADMIN"):只有拥有 ADMIN 角色的用户才能访问
- formLogin():启用表单登录页面
- httpBasic():支持 HTTP Basic 认证(适合 API 调试)
自定义用户认证逻辑
通过实现 UserDetailsService 接口加载用户信息:
@Servicepublic class CustomUserDetailsService implements UserDetailsService {
@Autowired
private UserRepository userRepository;
@Override
public UserDetails loadUserByUsername(String username) throws UsernameNotFoundException {
User user = userRepository.findByUsername(username)
.orElseThrow(() -> new UsernameNotFoundException("用户不存在: " + username));
return org.springframework.security.core.userdetails.User
.withUsername(user.getUsername())
.password(user.getPassword())
.roles(user.getRoles().toArray(new String[0]))
.build();
}
}
确保数据库中的密码是使用 PasswordEncoder 加密存储的。
配置密码编码器
推荐使用 BCrypt:
@Beanpublic PasswordEncoder passwordEncoder() {
return new BCryptPasswordEncoder();
}
注册或保存用户时,必须用此编码器对明文密码加密后再存入数据库。
基本上就这些。配合 REST 接口和 JWT 可进一步实现无状态认证。初期用内置登录页快速验证流程即可。安全机制不复杂但容易忽略细节,比如角色前缀 ROLE_ 和权限表达式的匹配规则。
本篇关于《SpringSecurity用户认证授权教程》的介绍就到此结束啦,但是学无止境,想要了解学习更多关于文章的相关知识,请关注golang学习网公众号!
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
152 收藏
-
129 收藏
-
334 收藏
-
431 收藏
-
294 收藏
-
292 收藏
-
183 收藏
-
288 收藏
-
271 收藏
-
484 收藏
-
278 收藏
-
310 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习