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条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- SpringBoot2整合MyBatis,连接MySql数据库做增删改查操作
- Docker使用Oracle官方镜像安装(12C,18C,19C)
- Springboot2将连接池hikari替换为druid,体验最强大的数据库连接池
- MySQL数据库在高并发下的优化方案
- Docker快速安装Oracle11G,搭建oracle11g学习环境
- SpringBoot2编写第一个Controller,响应你的http请求并返回结果
- CentOS7,8上快速安装Gitea,搭建Git服务器
- CentOS6,7,8上安装Nginx,支持https2.0的开启
- CentOS8编译安装MySQL8.0.19
- Dcoker安装(在线仓库),最新的服务器搭配容器使用