微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Spring与Shiro整合 静态注解授权

Spring与Shiro整合 静态注解授权

作者 : Stanley 罗昊

【转载请注明出处和署名,谢谢!】

使用Shiro的种类

首先,Shiro的授权方式共有三种;

1.编程式授权(不推荐)

2.注解式授权(普遍使用【力荐】)

注:第一个始于基于角色控制权限,就是你这个用户拥有那些权限;

       第二个基于权限控制,判断你这个角色是否拥有这项权限,如果有给放行,如果没有被拦截;这个一般是判断数据库User表中会有一个权限列;

3.Jsp式授权(一般前端UI有对应解决方案)

注:jsp标签方式只是表面上不将此功能显示,但是如果有恶意用户绕过,直接输入ip地址+接口名称即可访问,所以必须配合后端一起使用;

了解授权(注解方式)

首先,我们在jsp页面上编写几个a标签

 

 

 我们看到了分别有增、改、删,这也就对应我们后台控制器(Conteoller)中mapping内的Url拦截地址:

 

 

 我们现在开始将以上操作纳入Shiro管理;这一步,仅仅就是让这些Url纳入并被Shiro管理在Conteoller中声明;,

将Url交给Shiro管理

纳入很简单,只需要在这个接口上加上注解即可:

注:第一个始于基于角色控制权限,就是你这个用户拥有那些权限;

       第二个基于权限控制,判断你这个角色是否拥有这项权限,如果有给放行,如果没有被拦截;这个一般是判断数据库User表中会有一个权限列【推荐】;

所以我们会用第二种,直接在用户请求这个接口之前,判断这个注解中的表达式,如果你有save那你就进来,如果没有,你就被拦截

具体写法:

 

 解析:其中,employee可以写成Controller的前缀名称

Spring-Shiro.xml文件中配置

编写完注解后,我们依然需要将配置文件中加入一段代码

 

 1.开启Aop对类代理

我们可以看察觉到,我们的注解是不是都贴在Controller类内的方法上,在这方法中,我们不需要注入或引入任何接口,原因就是我们需要在xml文件中配置,也可以这样理解,我们把需要引入的jar包以及继承的接口都放入xml文件中;

2.开启Shiro注解支持

我们这个注解,我们贴上去并让它起到作用(权限控制)的话,就需要再此配置,详细说就是,第三方程序的依赖,Spirng本身没有,所以我们需要依赖第三方程序从而实现权限的控制;

注意:其中,上面的securityManager就是配置安全管理器的SecurityManager(同在Spring-Shiro.xml文件中):

 

 

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。