protege查看类的url_SpringBootSecurity学习(11)网页版登录之URL动态权限

动态权限

前面讨论用户登录认证的时候,根据用户名查询用户会将用户拥有的角色一起查询出来,自动实现判断当前登录用户拥有哪些角色。可以说用户与角色之间的动态配置和判断security做的非常不错。不过在配置方法级别的权限的时候,使用注解虽然是一种比较优雅的方式,但是要求在开发的时候就知道当前url对应哪些角色,无法实现动态的配置,而实际的项目中,每个链接允许哪些角色访问也不是一成不变的,因此下面我们来实现自己的路由判断。

创建表

前面的讨论中,我们创建了用户表,角色表和用户角色中间表,下面来创建菜单功能表,并把现在有的url链接添加进去:

d0da89465dc8da9b12a0aeacdb0b15c4.png

然后创建角色菜单中间表,加入角色与url之间的对应关系:

3015ccf0b7bd54d481f2c30ac31360e9.png

创建基础类

首先去掉前面的方法级别权限的注解,然后创建菜单实体类:

4bfd4e233f88e3362ab0759935e67936.png

创建查询方法,根据url查询次链接对应的所有角色名称:

3259aa68e3dd6e2d2529ab6d66ca6413.png

对应的sql语句如下:

47123e7a4fcd1d7c795867f9e20862c0.png

路由动态获取角色

首先增加一个处理类,在收到访问的时候,动态获取当前url的角色:

6f089bfc9549c6e6325118553af77e05.png

新建一个ObjectPostProcessor类,将这个处理类配置到其中:

8f152dc6b90fc560c33d42a6343a0f86.png

最后将新建的ObjectPostProcessor类配置到权限配置方法中:

0d8c4cf0e695329806c4cf18a4f85af8.png

路由决策管理

用户与角色是多对多的关系,url与角色也是多对多的关系,这里的设定是,只要用户与url对应的角色中有相同的存在,就表示用户有访问的权限。首先看一下对应判断的处理类:

a025d58439efa93d0618a52d9d352d41.png

使用双重for循环进行判断,并进行结果投票。在注释中可以看到,使用不同的方式会产生不同的策略。下一步在security配置类中配置路由策略方法:

b147af02cd847a728f2d5e7c471d2cf3.png

除了UrlRoleAuthHandler类,其它决策类使用的都是security存在的类,最后在权限配置中配置决策管理:

d933d537795effd26ad2ab84b34aca05.png

测试

这样动态权限url就配置好了,根据上面方法中的数据,可以登录查看是否具有对应的url权限,没有配置的是否不具备权限。

代码地址:https://gitee.com/blueses/spring-boot-security 11

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值