前言
上篇文章介绍了动态用户角色资源的权限管理,在结尾,也提到了个比较实际的问题
一般系统是不会让用户去点击了菜单才发现没有权限访问,而是针对不同的用户,动态显示不同的菜单
简单介绍
那么怎么实现呢,通过Spring Securiyt的标签和后台动态标签验证就可以解决
那么,要想引用Spring Security标签,那么就要引入相应的标签库,因为小编这里用的前端模板是Thymeleaf,所以引入标签库如下:
1 | <dependency> |
注意,因为我这里使用的是 Spring Security5 的版本,所以对应也是
thymeleaf-extras-springsecurity5
如果是 Spring Security4 的话对应就是
thymeleaf-extras-springsecurit4
然后每个页面只需要在html头部引入
即可使用 Spring Security 标签库
实现
这里基本介绍就介绍完了,下面开始说下怎么实现的动态显示菜单的问题
在需要动态显示的菜单上,加上
<标签 sec:authorize=“hasAuthority(‘key’)”>
key则为资源表中的资源标识字段
那我们看看接上篇文章的代码,现在我想给我的菜单1、菜单2、菜单3动态显示,那么实现代码如下:
1 |
|
那么到这里我们就算完成了,我们看看效果
这里我们先用admin管理员角色登录,首页如下:
然后,再用teacher教师角色登录,首页如下:
最后,再用student学生角色登录,首页如下:
可以看到,对应不同的权限,显示不同的资源按钮
结束语
那么基本代码和效果也演示完毕了
源码获取方式加加入QQ交流群(715224124),进群找群主要源码,如果有问题,可以提出疑问,群主会尽量帮助解决~
希望能帮助到大家,如果有不好或者错误的地方希望能多多提出,谢谢大家~