SSM+自定义注解+自定义标签实现权限管理细粒度控制

Demo下载

1.原理

权限控制其实所有框架原理都是一样。无非是将你系统中用户拥有的资源和访问的资源做比较,如果用户拥有那么就可以访问,如果没有就不允许访问。

2.所用知识点准备

传统系统中自己写的权限系统只能做菜单,或者功能点击的时候才能判断权限(比如用户的增加,删除,修改 按钮权限无法加载页面列表时候控制显示,如果使用过shiro框架的童鞋就会明白 shiro页面是通过<shiro:hasRole name="abc"> 功能按钮</shiro>来控制的,如果用户拥有abc角色,那么就有shiro标签中的按钮功能

受此启发我们可以自定义jsp 中的标签来实现类似的功能

3.jsp 自定义标签讲解

需要在WEB-INF下定义tld文件夹 在改文件夹中写自己的标签节点 比如我的权限标签如果下:


自定义权限标签中类的处理逻辑



4.页面引用

在你所用jsp页面引入 <%@taglib prefix="wzw" uri="http://com.wzw.dev/html/permission" %> prefix 和 uri 是你tld中定义的名称

页面按钮控制比如:

<wzw:hasButton buttonPermission="location:edit"><a>定位管理编辑</a><br/></wzw:hasButton>

这只是显示控制 但是我们手动在游览器中访问也要控制。我们通常在拦截器中处理对应的权限拦截。但是为了防止frame中的地址访问不受拦截影响 ,又不想在拦截器中每一个不受影响的地址都添加进去。我们采用自定义注解来控制权限访问,并且也无形中提升了我们的代码逼格 有木有 哈哈哈!

5.自定义注解讲解


怎么去使用注解呢!首先要去拦截器获取到该方法的拦截器 判断方法上是否使用改注解的名称,如果有我们就去判断是否拥有该方法的访问资源权限

6.拦截器处理自定义注解



再看 userAuthValidate 方法



至此权限控制的核心逻辑全部写完!

小伙伴们可以点击Demo下载  来下载(备注:因为积分不多了,所以要求积分比较高,望理解,支持!)


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

你微笑莳很美丶

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值