首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >不检查用户授权:每个循环Thymeleaf

不检查用户授权:每个循环Thymeleaf
EN

Stack Overflow用户
提问于 2021-05-22 14:41:17
回答 1查看 58关注 0票数 0

有几个组织单位,每个单位都有一个自定义角色。在该页上,授权后,您需要显示仅用于此角色(部门)的按钮。此代码适用于:

代码语言:javascript
复制
<div>
  <a th:sec:authorize="hasRole('ROLE_DEP-1')" href="/userPage/department1" type="button">DEP-1</a>
  <a th:sec:authorize="hasRole('ROLE_DEP-2')" href="/userPage/department2" type="button">DEP-2</a>
  <a th:sec:authorize="hasRole('ROLE_DEP-3')" href="/userPage/department3" type="button">DEP-3</a>
  <a th:sec:authorize="hasRole('ROLE_DEP-4')" href="/userPage/department4" type="button">DEP-4</a>
</div>

不过,我认为用人手书写所有细分单位是不正确的,因为将来可能会增加更多的单位。我决定通过th完成:每个Thymeleaf循环:

代码语言:javascript
复制
<div th:each="d : ${departments}">
   <a th:sec:authorize="hasRole('+${d.role.name}+')" href="/userPage/department" type="button" th:text="${d.shortName}"></a>
</div>

但不幸的是,这是行不通的,按钮没有显示。正确显示角色名称。部门和角色表之间的关系是1:1,我不明白为什么它不能工作。在这个函数中可能需要有一个特殊的语法:

"hasRole('+${d.role.name}+')“

EN

回答 1

Stack Overflow用户

发布于 2021-05-22 17:03:07

您将需要使用预处理

代码语言:javascript
复制
<div th:each="d : ${departments}">
   <a sec:authorize="hasRole(' + __${d.role.name}__ +')" href="/userPage/department" type="button" th:text="${d.shortName}"></a>
</div>
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/67650751

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档