Shiro 基于注解和标签实现的授权认证过程

将 Shiro 作为应用的权限基础 三:基于注解实现的授权认证过程 [url]http://blog.csdn.net/tch918/article/details/13849325[/url]
Apache Shiro 注解方式授权 [url]http://blog.csdn.net/peterwanghao/article/details/8165014[/url]


[color=red][b]基于注解[/b][/color]
[url]http://jinnianshilongnian.iteye.com/blog/2029717[/url]
[color=blue][b]@RequiresPermissions[/b][/color]
授权处理过程
认证通过后接受 Shiro 授权检查,授权验证时,需要判断当前角色是否拥有该权限。
只有授权通过,才可以访问受保护 URL 对应的资源,否则跳转到“未经授权页面”。
如果我们自定义Realm实现,比如我后面的例子中,自定义了ShiroDbRealm类,当访问被@RequiresPermissions注解的方法时,会先执行ShiroDbRealm.doGetAuthorizationInfo()进行授权。
@RequiresPermissions (value={“user:a”, “user:b”}, logical= Logical.OR)

[color=blue][b]@RequiresAuthentication[/b][/color]
可以用户类/属性/方法,用于表明当前用户需是经过认证的用户。 要求当前Subject 已经在当前的session 中被验证通过才能被访问或调用


[color=blue][b]@RequiresGuest[/b][/color]
要求当前的Subject 是一个"guest",也就是说,他们必须是在之前的session 中没有被验证或被记住才能被访问或调用


[color=blue][b]@RequiresRoles("administrator")[/b][/color]
要求当前的Subject 拥有所有指定的角色。如果他们没有,则该方法将不会被执行,而且AuthorizationException 异常将会被抛出。


[color=blue][b]
@RequiresUser[/b][/color]
RequiresUser 注解需要当前的Subject 是一个应用程序用户才能被注解的类/实例/方法访问或调用。一个“应用程序用户”被定义为一个拥有已知身份,或在当前session 中由于通过验证被确认,或者在之前session 中的'RememberMe'服务被记住。


[color=red][b]基于JSP TAG的授权实现[/b][/color]
[url]http://jinnianshilongnian.iteye.com/blog/2026398[/url]
Shiro提供了一套JSP标签库来实现页面级的授权控制。
在使用Shiro标签库前,首先需要在JSP引入shiro标签:
<%@ taglib prefix="shiro" uri="http://shiro.apache.org/tags" %>  


hasRole标签
验证当前用户是否属于该角色
<shiro:hasRole name="administrator">    
<a href="admin.jsp">Administer the system</a>
</shiro:hasRole>


hasPermission标签
验证当前用户是否拥有制定权限
<shiro:hasPermission name="user:create">    
<a href="createUser.jsp">Create a new User</a>
</shiro:hasPermission>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值