LoopAuth 2.X 版本发布,这可能是你第一次使用 ABAC 鉴权
LoopAuth
发布已经有些时日了,在LoopAuth
1.X版本中,一直使用Rbac的鉴权方式。
LoopAuth
这个项目在创建初期,就已经思考加入ABAC
的鉴权模式。
9月份摆烂一个月后,LoopAuth
2.X版本现在已发布: 重构完成,加入ABAC
鉴权模式,将原有核心模块拆分为Session
、RBAC
、ABAC
三块。
相关链接
ABAC初体验
添加依赖
${version}
请查看版本历史,请使用最新正式版,且版本与其余拓展最好保持一致
<!-- LoopAuth的Springboot插件 --> <dependency> <groupId>com.sobercoding</groupId> <artifactId>LoopAuth-spring-boot-starter</artifactId> <version>${version}</version> </dependency>
实现AbacInterface
接口
- LoopAuthHttpMode为请求类型的枚举,包括GET、PUT、POST或ALL等等所有常见的请求类型
public class AbacInterFaceImpl implements AbacInterface { /** * 获取一个或多个路由/权限代码所属的 规则 * @param route 路由 * @param loopAuthHttpMode 请求方式 * @return 去重后的集合 */ @Override public Set<Policy> getPolicySet(String route, LoopAuthHttpMode loopAuthHttpMode) { // 这里只做演示,自行编写的时候,请根据自己存储abac规则的方式查询获取 Set<Policy> set = new HashSet<>(); // 根据路由地址及请求方式查询 插入 if (route.equals("/test/abac") && loopAuthHttpMode.equals(LoopAuthHttpMode.GET)){ set.add(new Policy() // 规则名称 .setName("test") // 规则中的属性名称 及 属性值 用于后续进行 规则匹配校验 .setProperty("loginId", "2") ); } return set; } }
自动注入
- 在
AbacInterface
的实现类上加上@Component
注解即可
@Component public class AbacInterFaceImpl implements AbacInterface { ... }
手动注入
- 保证项目启动时执行下面语句即可
AbacStrategy.setAbacInterface(new PermissionInterfaceImpl());
初始化ABAC鉴权规则
- 需要保证项目启动时 执行以下代码
- 以下代码以匹配
loginId
为例 - 请根据自己需求更改
AbacStrategy.abacPoAndSuMap = new AbacPolicyFunBuilder() // 自定义登录id校验的鉴权规则 .setPolicyFun("loginId", // 创建规则校验及获取当前值的方式 new AbacPoAndSu() // 创建校验方式 value为当前值即setSupplierMap提供的值 // rule为规则的值即 Policy setProperty 的值 .setMaFunction((value, rule) -> { // 当前用户id需要与规则匹配才可访问 否则 抛出异常 if (!value.equals(rule)){ throw new LoopAuthPermissionException(LoopAuthExceptionEnum.NO_PERMISSION); } }) // 获得value方式 .setSupplierMap(() -> "2") ).build();
注入拦截器
@Component public class LoopAuthMvcConfigure implements WebMvcConfigurer { /** * 注册LoopAuth 的拦截器,打开注解式鉴权功能 */ @Override public void addInterceptors(InterceptorRegistry registry) { // abac拦截器 registry.addInterceptor(new InterceptorBuilder().Abac().builder()).addPathPatterns("/**"); } }
创建Controller
测试一下
- 可以更改
setSupplierMap()
中的返回值、或请求类型理解
@GetMapping("/test/abac") public String abac1(){ return "检测成功"; }

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
DBApi v3.1.2 已经发布,零代码开发 API 服务
DBApi v3.1.2 已经发布,零代码开发 API 服务 此版本更新内容包括: 支持动态申请token 集群版本使用redis作为元数据缓存 powershell脚本修复 修复高版本jdk不兼容问题 UI优化 UI显示API访问代码 详情查看:https://gitee.com/freakchicken/db-api/releases/v3.1.2
- 下一篇
妙码生花 - BuildAdmin v1.0.6 已经发布,后台管理系统
妙码生花 - BuildAdmin v1.0.6 已经发布,后台管理系统 此版本更新内容包括: Table组件增加多个插槽位,提供el-table-column支持 增加WEB端文件上传扩展文件 增加文件上传前的类型与大小检查 增加文件单位转字节的函数 增加系统配置管理类 新增以编程的方式删除依赖的功能 新增模块安装时对互斥模块的检测 增加多个系统预置事件定义 增加发送邮件接口 增加发送短信接口 增加手机验证账户验证方式 增加responseType json 以外类型的处理逻辑 增加编程式添加系统配置中的快捷配置入口的方法 增加清理浏览器缓存的快捷按钮 升级element-plus版本到2.2.17 优化表单验证 优化表格的单元格渲染 优化多处类型定义 优化后端数据库字段读取函数 优化数据管理中数据表和控制器列表的加载 优化控制台页面暗黑模式下的文字颜色 优化模块安装时对互斥模块的检测 优化上传组件 WEB端语言包文件无限层级读取 表格顶部菜单按钮图标在暗黑模式时的样式优化 禁用模块时可以选择保留一些由模块添加的依赖项 模块状态不为已安装时不定义AppInit事件 资源完整路径处理时...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- Red5直播服务器,属于Java语言的直播服务器
- CentOS7设置SWAP分区,小内存服务器的救世主
- CentOS7安装Docker,走上虚拟化容器引擎之路
- SpringBoot2编写第一个Controller,响应你的http请求并返回结果
- CentOS关闭SELinux安全模块
- CentOS7,CentOS8安装Elasticsearch6.8.6
- Jdk安装(Linux,MacOS,Windows),包含三大操作系统的最全安装
- Linux系统CentOS6、CentOS7手动修改IP地址
- Windows10,CentOS7,CentOS8安装MongoDB4.0.16
- CentOS8安装Docker,最新的服务器搭配容器使用