Apache Shiro 标签库
Shiro 提供了一套 JSP 标签库来实现页面级的授权控制。
在使用 Shiro 标签库前,首先需要在 JSP 引入 shiro 标签:
<%@ taglib prefix="shiro" uri="http://shiro.apache.org/tags" %>
下面一一介绍 Shiro 的标签:
guest 标签
验证当前用户是否为'访客',即未认证(包含未记住)的用户。
<shiro:guest>
Hi there! Please <a href="login.jsp">Login</a> or <a href="signup.jsp">Signup</a> today!
</shiro:guest>
user 标签
认证通过或已记住的用户。
<shiro:user>
Welcome back John! Not John? Click <a href="login.jsp">here</a> to login.
</shiro:user>
authenticated 标签
已认证通过的用户。不包含已记住的用户,这是与 user 标签的区别所在。
<shiro:authenticated>
<a href="updateAccount.jsp">Update your contact information</a>.
</shiro:authenticated>
notAuthenticated 标签
未认证通过用户,与 authenticated 标签相对应。与 guest 标签的区别是,该标签包含已记住用户。
<shiro:notAuthenticated>
Please <a href="login.jsp">login</a> in order to update your credit card information.
</shiro:notAuthenticated>
principal 标签
输出当前用户信息,通常为登录帐号信息。
Hello, <shiro:principal />, how are you today?
hasRole 标签
验证当前用户是否属于该角色。
<shiro:hasRole name="administrator">
<a href="admin.jsp">Administer the system</a>
</shiro:hasRole>
lacksRole 标签
与 hasRole 标签逻辑相反,当用户不属于该角色时验证通过。
<shiro:lacksRole name="administrator">
Sorry, you are not allowed to administer the system.
</shiro:lacksRole>
hasAnyRole 标签
验证当前用户是否属于以下任意一个角色。
<shiro:hasAnyRoles name="developer, project manager, administrator">
You are either a developer, project manager, or administrator.
</shiro:hasAnyRoles>

