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

Spring Boot 集成 Apache Shiro 实现权限管理

在企业级应用开发中,权限管理和用户认证是非常重要的组成部分。Spring Boot 以其便捷的配置和快速的开发流程而受到开发者们的青睐。Apache Shiro 是一个强大且易用的 Java 安全框架,可以非常容易地开发出足够安全的应用。本文将介绍如何在 Spring Boot 应用中集成 Apache Shiro 来实现权限管理。

一、环境准备

  1. 开发工具
  2. IntelliJ IDEA 或 Eclipse
  3. Maven
  4. Java 11+
  5. 项目初始化
  6. 使用 Spring Initializr 创建一个新的 Spring Boot 项目。
  7. 添加 Web 和 JPA 依赖。
  8. 添加 Shiro 依赖: 在 pom.xml 文件中添加 Shiro 的相关依赖。
xml

深色版本

1<dependencies>
2    <!-- Shiro -->
3    <dependency>
4        <groupId>org.apache.shiro</groupId>
5        <artifactId>shiro-spring</artifactId>
6        <version>1.12.4</version>
7    </dependency>
8    <dependency>
9        <groupId>org.apache.shiro</groupId>
10        <artifactId>shiro-ehcache</artifactId>
11        <version>1.12.4</version>
12    </dependency>
13    <!-- 其他依赖 -->
14</dependencies>

二、配置文件

  1. application.properties
  2. properties
  3. 深色版本
  4. 1# Shiro 配置 2shiro.cacheManager.ehCacheManager.shared=true
  5. ShiroConfig.java: 这里我们定义 Shiro 的配置类。
java

深色版本

1@Configuration
2public class ShiroConfig {
3
4    @Bean
5    public SecurityManager securityManager() {
6        DefaultWebSecurityManager securityManager = new DefaultWebSecurityManager();
7        securityManager.setRealm(myShiroRealm());
8        securityManager.setCacheManager(cacheManager());
9        return securityManager;
10    }
11
12    @Bean
13    public MyShiroRealm myShiroRealm() {
14        return new MyShiroRealm();
15    }
16
17    @Bean
18    public CacheManager cacheManager() {
19        return new EhCacheManager();
20    }
21
22    @Bean
23    public ShiroFilterFactoryBean shiroFilter(SecurityManager securityManager) {
24        ShiroFilterFactoryBean factoryBean = new ShiroFilterFactoryBean();
25        factoryBean.setSecurityManager(securityManager);
26        Map<String, String> filterChainDefinitionMap = new LinkedHashMap<>();
27        // 设置匿名访问路径
28        filterChainDefinitionMap.put("/login", "anon");
29        // 设置需要认证的路径
30        filterChainDefinitionMap.put("/**", "authc");
31        factoryBean.setFilterChainDefinitionMap(filterChainDefinitionMap);
32        return factoryBean;
33    }
34}

三、自定义 Realm

  1. MyShiroRealm.java: 实现 AuthorizingRealm 接口来定义认证逻辑。
java

深色版本

1@Component
2public class MyShiroRealm extends AuthorizingRealm {
3
4    @Override
5    protected AuthenticationInfo doGetAuthenticationInfo(AuthenticationToken token) throws AuthenticationException {
6        // 从 token 中获取用户名
7        String username = (String) token.getPrincipal();
8        // 查询数据库验证用户名和密码
9        if ("admin".equals(username) && "password".equals(token.getCredentials().toString())) {
10            return new SimpleAuthenticationInfo(username, "password", getName());
11        }
12        throw new UnknownAccountException();
13    }
14
15    @Override
16    protected AuthorizationInfo doGetAuthorizationInfo(PrincipalCollection principals) {
17        String username = (String) principals.getPrimaryPrincipal();
18        // 查询数据库获取该用户的权限信息
19        if ("admin".equals(username)) {
20            SimpleAuthorizationInfo info = new SimpleAuthorizationInfo();
21            info.addRole("admin");
22            info.addStringPermission("user:read");
23            return info;
24        }
25        return null;
26    }
27}

四、控制器与视图

  1. LoginController.java: 实现登录功能。
java

深色版本

1@Controller
2public class LoginController {
3
4    @GetMapping("/login")
5    public String login() {
6        return "login";
7    }
8
9    @PostMapping("/login")
10    public String login(@RequestParam String username, @RequestParam String password, Model model) {
11        try {
12            Subject currentUser = SecurityUtils.getSubject();
13            UsernamePasswordToken token = new UsernamePasswordToken(username, password);
14            currentUser.login(token);
15            return "redirect:/dashboard";
16        } catch (UnknownAccountException e) {
17            model.addAttribute("error", "未知账户!");
18            return "login";
19        } catch (IncorrectCredentialsException e) {
20            model.addAttribute("error", "密码错误!");
21            return "login";
22        }
23    }
24}

五、总结

通过上述步骤,我们成功地在 Spring Boot 应用中集成了 Apache Shiro,并实现了基本的权限管理。当然,实际应用中还需要考虑更多的细节,比如更复杂的权限判断逻辑、异常处理、多数据源支持等。希望这篇博客能为你的项目提供一些有用的参考。

相关文章:

  • 节点使用简介:comfyui-photoshop
  • unity2107,导入spine骨骼动画报错
  • 深入浅出Java RestClient与Elasticsearch:一次简单的聚合查询实现
  • 旋转字符串 | LeetCode-796 | 模拟 | KMP | 字符串匹配
  • 学习日志8.14--ALC(Access Control List)访问控制列表
  • 【虚拟化】计算虚拟化技术简介,CentOS使用KVM、QEMU安装并管理虚拟机
  • 放飞孔明灯
  • 分班结果发布必备工具!
  • PHP反序列化
  • C语言手撕数据结构代码_顺序表_静态存储_动态存储
  • 赋能基层,融合创新:EasyCVR视频汇聚平台构建平安城市视频共享系统
  • 通过网关将数据上传到两台eqmx服务器上
  • ArduinoIDE无法直接安装ESP32库解决方案(需梯子)
  • 数字IC/FPGA校招宝典--笔试题(四)
  • 【超高速传输】慧能泰eMarker系列助力USB4 80Gbps新时代!
  • Python | Leetcode Python题解之第327题区间和的个数
  • 算法板子:DP背包问题——01背包、完全背包、多重背包
  • vue 日期控件 100天内的时间禁用不允许选择
  • luckyexcel 编辑预览excel文件
  • 前端构建URL的几种方法比对,以及函数实现
  • 江西吉水通报一男子拒服兵役:不得考公,两年内经商、升学等受限
  • 国羽用冠军开启奥运周期,林丹:希望洛杉矶奥运取得更好成绩
  • 男子发寻母视频被警方批评教育,律师:发寻亲信息是正当行为
  • 中国潜水救捞行业协会发布《呵护潜水员职业健康安全宣言》
  • 城事 | 重庆新增热门打卡地标,首座熊猫主题轨交站亮相
  • 巫蛊:文化的历史暗流