首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >如何使用spring安全插件获取当前用户角色?

如何使用spring安全插件获取当前用户角色?
EN

Stack Overflow用户
提问于 2011-06-24 19:34:01
回答 6查看 23.1K关注 0票数 21

我在我的grails应用程序中使用了spring-security-core插件。我需要知道当前用户在控制器操作中的角色。我怎样才能检索到它?

EN

回答 6

Stack Overflow用户

回答已采纳

发布于 2011-06-24 20:06:07

您可以将springSecurityService注入到控制器中:

def springSecurityService

然后在你的行动中,调用:

def roles = springSecurityService.getPrincipal().getAuthorities()

请参阅文档here

票数 32
EN

Stack Overflow用户

发布于 2011-06-24 20:19:52

在控制器中,您可以使用插件添加到元类中的两种方法:getPrincipalisLoggedIn

代码语言:javascript
复制
def myAction = {
   if (loggedIn) {
      // will be a List of String
      def roleNames = principal.authorities*.authority
   }
}

如果该操作是安全的,则可以跳过loggedIn/isLoggedIn()检查。

票数 20
EN

Stack Overflow用户

发布于 2014-02-06 11:24:49

如果只需要检查用户是否属于某个特定的角色,那么可以使用SpringSecurityUtils.ifAllGranted,它以单个字符串作为参数,其中包含一个逗号分隔的角色列表。如果当前用户属于所有用户,则返回true。SpringSecurityUtils也有像ifAnyGrantedifNotGranted等方法,所以无论你想要实现什么,它都应该可以工作。

票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/6467167

复制
相关文章

相似问题

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