[英]Spring Security switch case in JSTL Tags
有沒有辦法轉換窗體的jsp代碼
<security:authorize access="hasRole('ROLE_USER')">You're an user</security:authorize>
<security:authorize access="hasRole('ROLE_ADMIN')">You're an admin</security:authorize>
<security:authorize access="hasRole('ROLE_SADMIN')">You're a superadmin</security:authorize>
到另一種形式,類似於以下(不起作用)?
<c:choose>
<c:when test="hasRole('ROLE_USER')">
You're an user
</c:when>
<c:when test="hasRole('ROLE_ADMIN')">
You're an admin
</c:when>
<c:when test="hasRole('ROLE_SADMIN')">
You're a superadmin
</c:when>
<c:otherwise>
You have no relevant role
</c:otherwise>
</c:choose>
更確切地說,有沒有辦法用JSTL標簽替換這個Spring Security taglib功能?
您可以使用<security:authorize/>
標記的var
屬性來創建:
一個頁面范圍的變量,其中將寫入標記評估的布爾結果,允許在頁面中隨后重用相同的條件而無需重新評估。
<security:authorize access="hasRole('ROLE_USER')" var="isUser" />
<security:authorize access="hasRole('ROLE_ADMIN')" var="isAdmin" />
<security:authorize access="hasRole('ROLE_SADMIN')" var="isSuperUser" />
<c:choose>
<c:when test="${isSuperUser}">
You're a superadmin
</c:when>
<c:when test="${isAdmin}">
You're an admin
</c:when>
<c:when test="${isUser}">
You're an user
</c:when>
<c:otherwise>
You have no relevant role
</c:otherwise>
</c:choose>
Workarround:如果只有這個簡單的hasRole(XXX)
表達式,那么你可以擁有一個包含當前用戶角色的變量。 這個變量可以由控制器填充,或者在幾乎所有jsps中需要時,由Spring HandlerInterceptor
或Servlet Filter(在Spring Security Filter之后注冊)填充。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.