Java Web开发实战与项目——Spring Security与权限管理实现
Web应用中,权限管理是系统安全的核心部分,确保用户只能访问他们被授权的资源。Spring Security是Spring框架中的一个安全框架,它提供了强大的认证和授权功能,用于实现用户认证和权限控制。本章节将详细讲解如何使用Spring Security实现用户角色与权限管理,并演示如何在Spring Boot应用中进行权限控制。
1. 用户角色与权限设计
1.1 角色与权限的概念
在权限管理中,角色(Role)和权限(Permission)是两个核心概念:
- 角色:角色通常代表用户在系统中的职责或职能,例如“管理员”、“普通用户”、“客户”等。
- 权限:权限是对特定操作的访问授权,例如“查看订单”、“管理商品”等。
一个用户通常会被分配一个或多个角色,而每个角色则关联到一组特定的权限。通过这种方式,可以灵活地控制不同用户在系统中可以访问和执行哪些操作。
1.2 角色与权限的设计
在实际应用中,角色和权限的设计可以参考以下几点:
- 系统角色设计:
- 管理员(Admin):具备管理用户、配置系统等高级权限。
- 普通用户(User):通常只能访问自己的数据,进行基本操作。
- 访客(Guest):一般情况下只能查看公开资源。
- 权限设计:
- 每个角色对应一组具体的权限,如“查看用户”、“编辑商品”、“删除订单”等。
- 权限的粒度设计可以根据需求来调整,必要时还可以考虑权限的继承和组合。
通常的做法是将权限分为几个类别,并通过权限模型(如RBAC,基于角色的访问控制)来管理。通过角色来集中的定义权限,从而简化管理。
2. 使用Spring Security进行权限管理
2.1 配置Spring Security
Spring Security提供了很多功能来处理应用中的安全问题,如认证、授权、会话管理、加密等。要实现权限管理,首先需要在Spring Boot项目中配置Spring Security。
- 添加Spring Security依赖
在pom.xml文件中添加Spring Security的依赖:
<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-security</artifactId>
</dependency>
- Spring Security配置类(
SecurityConfig.java)
@Configuration
@EnableWebSecurity
public class SecurityConfig extends WebSecurityConfigurerAdapter {@Autowiredprivate UserDetailsService userDetailsService;@Overrideprotected void configure(HttpSecurity http) throws Exception {http.authorizeRequests().antMatchers("/login", "/register").permitAll() // 允许访问登录和注册页面.antMatchers("/admin/**").hasRole("ADMIN") // 只有ADMIN角色可以访问/admin路径.antMatchers("/user/**").hasRole("USER") // 只有USER角色可以访问/user路径.anyRequest().authenticated() // 其他请求需要认证.and().formLogin().loginPage("/login").permitAll().and().logout().permitAll();}@Overrideprotected void configure(AuthenticationManagerBuilder auth) throws Exception {auth.userDetailsService(userDetailsService).passwordEncoder(new BCryptPasswordEncoder());}
}
2.2 用户实体与角色设计
在Spring Security中,用户的角色信息通常是存储在数据库中的。在设计用户和角色时,我们需要将用户与角色做映射。我们可以创建一个用户实体类,该类包含用户信息和角色。
用户实体类(User.java)
@Entity
public class User implements UserDetails {@Id@GeneratedValue(strategy = GenerationType.IDENTITY)private Long id;private String username;private String password;@ManyToMany(fetch = FetchType.EAGER)private Set<Role> roles;@Overridepublic Collection<? extends GrantedAuthority> getAuthorities() {return roles.stream().map(role -> new SimpleGrantedAuthority("ROLE_" + role.getName())).collect(Collectors.toList());}@Overridepublic String getUsername() {return username;}@Overridepublic String getPassword() {return password;}@Overridepublic boolean isAccountNonExpired() {return true;}@Overridepublic boolean isAccountNonLocked() {return true;}@Overridepublic boolean isCredentialsNonExpired() {return true;}@Overridepublic boolean isEnabled() {return true;}// getters and setters
}
角色实体类(Role.java)
@Entity
public class Role {@Id@GeneratedValue(strategy = GenerationType.IDENTITY)private Long id;private String name;@ManyToMany(mappedBy = "roles")private Set<User> users;// getters and setters
}
2.3 用户服务与角色赋值
通过UserDetailsService接口,Spring Security可以通过自定义的服务类来加载用户的角色信息。我们可以实现一个用户服务,用于从数据库加载用户和角色。
@Service
public class UserService implements UserDetailsService {@Autowiredprivate UserRepository userRepository;@Overridepublic UserDetails loadUserByUsername(String username) throws UsernameNotFoundException {User user = userRepository.findByUsername(username);if (user == null) {throw new UsernameNotFoundException("User not found");}return user;}
}
在SecurityConfig类中,我们注入了UserDetailsService,并通过它来加载用户信息。用户信息(如用户名和密码)与角色信息会一起存储在User实体中。
3. 实现基于角色的权限控制
Spring Security的一个关键特性是基于角色的访问控制。通过在控制器或服务方法上使用@PreAuthorize注解,或者通过HttpSecurity的配置,能够对不同角色的用户进行不同权限的访问控制。
3.1 基于角色的权限控制
在Spring Security中,基于角色的权限控制非常简单。通过hasRole()方法,我们可以配置哪些角色可以访问哪些资源。
基于角色的HTTP请求权限控制
在SecurityConfig配置类中,我们可以使用antMatchers来控制哪些请求路径可以由哪些角色访问。
@Override
protected void configure(HttpSecurity http) throws Exception {http.authorizeRequests().antMatchers("/admin/**").hasRole("ADMIN") // 只有ADMIN角色可以访问/admin路径.antMatchers("/user/**").hasRole("USER") // 只有USER角色可以访问/user路径.antMatchers("/public/**").permitAll() // 所有用户都可以访问/public路径.anyRequest().authenticated() // 其他请求需要认证.and().formLogin().loginPage("/login").permitAll().and().logout().permitAll();
}
基于角色的方法权限控制
Spring Security还支持方法级的权限控制,允许在方法上使用注解来限制权限。例如,我们可以通过@PreAuthorize注解来控制某些操作只有特定角色的用户才能执行。
@PreAuthorize("hasRole('ADMIN')")
public void deleteUser(Long userId) {// 删除用户的逻辑
}
- 角色权限的动态控制
有时我们需要动态地控制角色权限,例如将权限分配给特定用户,或在运行时基于一些条件控制用户的权限。Spring Security提供了@Secured和@PreAuthorize注解,可以灵活地进行这种配置。
@Secured("ROLE_ADMIN")
public void someAdminOnlyMethod() {// 仅管理员可以访问的功能
}
@PreAuthorize("hasAuthority('ROLE_USER') and #user.username == authentication.name")
public void updateUser(User user) {// 只有角色为USER的用户可以修改自己的信息
}
总结
Spring Security提供了强大的认证与授权功能,通过定义用户角色和权限,可以灵活地管理系统的安全性。本章介绍了如何设计用户角色与权限、如何使用Spring Security进行权限管理,以及如何基于角色实现细粒度的权限控制。通过这些方式,您可以在开发中确保不同用户访问不同资源的安全性。
关于作者:
15年互联网开发、带过10-20人的团队,多次帮助公司从0到1完成项目开发,在TX等大厂都工作过。当下为退役状态,写此篇文章属个人爱好。本人开发期间收集了很多开发课程等资料,需要可联系我

相关文章:
Java Web开发实战与项目——Spring Security与权限管理实现
Web应用中,权限管理是系统安全的核心部分,确保用户只能访问他们被授权的资源。Spring Security是Spring框架中的一个安全框架,它提供了强大的认证和授权功能,用于实现用户认证和权限控制。本章节将详细讲解如何使用Spring Securit…...
单元测试方法的使用
import java.util.Date; import org.junit.Test; /** java中的JUnit单元测试* * 步骤:* 1.选中当前项目工程 --》 右键:build path --》 add libraries --》 JUnit 4 --》 下一步* 2.创建一个Java类进行单元测试。* 此时的Java类要求:①此类是公共的 ②此类提供一个公共的无参…...
VScode内接入deepseek包过程(本地部署版包会)
目录 1. 首先得有vscode软件 2. 在我们的电脑本地已经部署了ollama,我将以qwen作为实验例子 3. 在vscode上的扩展商店下载continue 4. 下载完成后,依次点击添加模型 5. 在这里可以添加,各种各样的模型,选择我们的ollama 6. 选…...
flink写入hdfs数据如何保证幂等的?
在 Flink 中使用 HDFS Connector 将数据写入 HDFS 时,保证幂等性是一个重要的需求,尤其是在数据可靠性要求较高的场景下。以下是详细介绍如何通过 Flink 和 HDFS 的特性以及一些设计上的优化来实现幂等性。 一、Flink 的 Checkpoint 机制 Flink 的 Chec…...
newgrp docker需要每次刷新问题
每次都需要运行 newgrp docker 的原因: 当用户被添加到 docker 组后,当前会话并不会立即更新组信息,因此需要通过 newgrp docker 切换到新的用户组以使权限生效 如果不想每次都手动运行 newgrp docker,可以在终端中配置一个自动刷新的脚本。…...
LM_Funny-2-01 递推算法:从数学基础到跨学科应用
目录 第一章 递推算法的数学本质 1.1 形式化定义与公理化体系 定理1.1 (完备性条件) 1.2 高阶递推的特征分析 案例:Gauss同余递推4 第二章 工程实现优化技术 2.1 内存压缩的革新方法 滚动窗口策略 分块存储技术 2.2 异构计算加速方案 GPU并行递推 量子计…...
WDM_OTN_基础知识_波分站点与组网类型
为了便于理解,我们用高铁来打个比方,这是郑州与武汉的高铁,中间经过了许昌孝感等很多个站点,郑州武汉作为始发站和终点站,所有人员都是上车或下车,而许昌等中间站点,既有人员上下车,…...
机器视觉--索贝尔滤波
引言 在图像处理领域,边缘检测是一项至关重要的任务,它能够帮助我们识别图像中不同区域的边界,为后续的目标识别、图像分割等操作奠定基础。索贝尔滤波(Sobel Filter)作为一种经典的边缘检测算法,因其简单…...
网络分析仪E5071C的回波损耗测量
回波损耗(Return Loss)是评估射频/微波元件(如滤波器、天线、电缆等)信号反射特性的关键参数,反映端口阻抗匹配性能。E5071C矢量网络分析仪(VNA)通过以下步骤实现高精度回波损耗测量:…...
力扣-二叉树-98 验证二叉搜索树
思路 第一个特性,二叉搜索树的中序遍历是有序的,第二个特性,利用两个指针判断大小关系 代码 class Solution { public:TreeNode* pre NULL;bool isValidBST(TreeNode* root) {if(root NULL) return true;bool left isValidBST(root->…...
【动态规划】详解 0-1背包问题
文章目录 1. 问题引入2. 从 dfs 到动态规划3. 动态规划过程分析4. 二维 dp 的遍历顺序5. 从二维数组到一维数组6. 一维数组的遍历次序7. 背包的遍历顺序8. 代码总结9. 总结 1. 问题引入 0-1 背包是比较经典的动态规划问题,这里以代码随想录里面的例子来介绍下。总的…...
【Java线程池与线程状态】线程池分类与最佳实践
解析Java线程池与线程状态变化,结合运行机制与业务场景对照,帮助形成系统性知识。 一、线程池核心要素(五维模型) 采用「参数配置→处理流程→工作模式」三层递进结构 核心参数(线程池DNA) corePoolSiz…...
【小白学AI系列】NLP 核心知识点(八)多头自注意力机制
文章目录 **多头自注意力机制(Multi-Head Self-Attention)****核心概念** **1. 自注意力机制(Self-Attention)****2. 多头机制(Multi-Head Attention)****3. 为什么要用多头注意力机制?****4. 公…...
学习笔记——word中图目录、表目录 标题引用
目标1: 建立——图1-1 引用——图1-1 1在word文档中的引用——>插入题注 新建标签,然后命名为“图1-“。 点击确认,即可插入如图所示 图1- 1 春天 需要把图1-和后面那个1中间的空格删除,即 图1-1 春天 2怎么去引用这个“…...
3.3 Hugging Face Transformers核心功能模块深度解析
Hugging Face Transformers核心功能模块深度解析 一、模块化架构总览 #mermaid-svg-wxTV5vrEo7Y57IlW {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-wxTV5vrEo7Y57IlW .error-icon{fill:#552222;}#mermaid-svg-wxT…...
linux中设置脚本定时执行ntp命令同步时间
目录 一、背景二、过程1.到系统目录2.安装ntp3.创建文件夹4.创建脚本文件5.提升脚本文件权限6.设置执行时间:7.检查是否设置了执行器(执行后输出的内容为执行器中的定时执行内容)8.执行脚本文件9.查看日志文件,是否执行成功 三、总…...
map的使用(c++)
在了解map之前,我们先看看两个场景,通过这两个场景的对比,让我们知道为什么要存在存储双关键字的容器 场景一:判断一堆字符串中,某一个字符串是否出现过 在没学set容器之前,我们只能想到把这一堆字符串存到…...
毕业设计—基于Spring Boot的社区居民健康管理平台的设计与实现
🎓 毕业设计大揭秘!想要源码和文章?快来私信我吧! Hey小伙伴们~ 👋 毕业季又来啦!是不是都在为毕业设计忙得团团转呢?🤔 别担心,我这里有个小小的福利要分享给你们哦&…...
Python:蟒蛇绘制(一笔画)
一、题目要求 使用turtle库,绘制一个蟒蛇形状的图形。 二、代码展示 # 请在下方开始编写你的代码 import turtle turtle.setup(650,350,200,200) turtle.penup() turtle.fd(-250) turtle.pendown() turtle.pensize(25) turtle.pencolor("purple") turt…...
mysql查询判断函数,类似decode
mysql中没有decode函数,如果使用的话,会报如下错误:Error Code: 1305. FUNCTION stockdb.decode does not exist 如果要实现像 Oracle 数据库那样原生的 DECODE 函数,可以通过以下几种方式来实现类似 DECODE 函数的功能。 -- 创建…...
LibreVNA矢量网络分析仪深度解析:从入门到精通的全方位实战指南
LibreVNA矢量网络分析仪深度解析:从入门到精通的全方位实战指南 【免费下载链接】LibreVNA 100kHz to 6GHz 2 port USB based VNA 项目地址: https://gitcode.com/gh_mirrors/li/LibreVNA LibreVNA是一款覆盖100kHz至6GHz频率范围的开源矢量网络分析仪&#…...
从MSG_PEEK到错误处理:深入挖掘Linux网络编程中recvfrom/sendto的那些高级用法和坑
从MSG_PEEK到错误处理:深入挖掘Linux网络编程中recvfrom/sendto的那些高级用法和坑 在Linux网络编程的世界里,recvfrom和sendto这两个系统调用就像是一对默契十足的搭档,它们支撑起了无数基于UDP协议的网络应用。但当你真正深入到高性能网络服…...
基于大语言模型的婚恋情感助手:技术架构与伦理实践
1. 项目概述:当大语言模型遇见婚恋场景最近在GitHub上看到一个挺有意思的项目,叫saofund/marrywise-llm。光看名字,marrywise这个词就挺有嚼头,结合llm,基本能猜到这是一个将大语言模型(LLM)应用…...
概率论在机器学习中的核心应用与实践
1. 概率论与机器学习的共生关系 概率论是机器学习领域最基础也最容易被低估的数学工具。我在工业界参与过的所有真实项目里,从简单的用户点击率预测到复杂的自动驾驶决策系统,概率模型都扮演着核心角色。举个实际案例:当我们为电商平台构建推…...
利用 Taotoken 实现多模型 API 的自动化测试与监控
利用 Taotoken 实现多模型 API 的自动化测试与监控 1. 多模型测试场景与 Taotoken 优势 在构建基于大模型的应用时,确保 API 的稳定性和性能至关重要。Taotoken 提供的统一接口允许开发者通过单一接入点调用多个模型,这为自动化测试和监控提供了便利。…...
初创公司如何借助 Taotoken 统一 API 快速原型验证多个大模型能力
初创公司如何借助 Taotoken 统一 API 快速原型验证多个大模型能力 1. 统一接入降低技术门槛 对于资源有限的初创团队而言,直接对接多个大模型厂商的 API 存在显著的技术与管理成本。不同厂商的接口规范、认证方式和返回格式各异,团队需要为每个供应商编…...
FFXIV ACT动画跳过插件完整指南:3分钟学会自动化副本体验
FFXIV ACT动画跳过插件完整指南:3分钟学会自动化副本体验 【免费下载链接】FFXIV_ACT_CutsceneSkip 项目地址: https://gitcode.com/gh_mirrors/ff/FFXIV_ACT_CutsceneSkip 在《最终幻想XIV》中国服务器中,副本动画跳过插件FFXIV_ACT_CutsceneSk…...
使用Taotoken CLI工具一键配置团队开发环境
使用Taotoken CLI工具一键配置团队开发环境 1. 安装Taotoken CLI工具 Taotoken CLI工具提供两种安装方式,适用于不同使用场景。对于需要频繁使用CLI的团队管理员,推荐全局安装: npm install -g taotoken/taotoken对于临时性配置或CI/CD环境…...
基于Notion与Next.js构建现代化静态博客:零运维、高性能的CMS解决方案
1. 项目概述:一个基于Notion的现代化博客系统 如果你和我一样,既想拥有一个设计精美、功能现代的独立博客,又不想被繁琐的服务器运维、数据库管理和复杂的发布流程所困扰,那么 tangly1024/NotionNext 这个项目绝对值得你花时间…...
腾讯 ai 应用开发 一面
1.项目里是把skill直接塞进system prompt的,如果skill太多,占用上下文窗口太大,怎么处理 不能把所有skill常驻塞进systemprompt,这样会带来三个问题:上下文窗口被占满、候选技能噪声太大、模型在选择skill 时更容易混淆。更合理的…...
