Недавно я перешел с плагина JSecurity на Spring Security. Как мне получить аутентифицированного пользователя из моих контроллеров?
Grails и Spring Security: как получить аутентифицированного пользователя из контроллера?
Ответы (6)
Я использую 0.5.1, и у меня работает следующее:
class EventController {
def authenticateService
def list = {
def user = authenticateService.principal()
def username = user?.getUsername()
.....
.....
}
}
В настоящее время это не задокументировано, но в установочном файле плагина есть 3 метода, которые он добавляет к каждому контроллеру, поэтому вам фактически не нужно вводить службу аутентификации:
private void addControllerMethods(MetaClass mc) {
mc.getAuthUserDomain = {
def principal = SCH.context?.authentication?.principal
if (principal != null && principal != 'anonymousUser') {
return principal?.domainClass
}
return null
}
mc.getPrincipalInfo = {
return SCH.context?.authentication?.principal
}
mc.isUserLogon = {
def principal = SCH.context?.authentication?.principal
return principal != null && principal != 'anonymousUser'
}
}
Это означает, что вы можете просто позвонить
principalInfo
Чтобы получить главный объект. У него также есть «isUserLogin», чтобы увидеть, зарегистрирован ли пользователь, и «authUserDomain», чтобы получить фактический экземпляр класса домена (Person/User), связанный с принципалом вошедшего в систему пользователя.
Следующий код взят из модуля Spring Security Core (версия: 1.1.2) - Справочная документация — раздел 6.2
Grails.plugins.springsecurity.SpringSecurityService предоставляет служебные функции безопасности. Это обычная служба Grails, поэтому вы используете внедрение зависимостей, чтобы внедрить ее в контроллер, службу, taglib и т. д.:
class SomeController {
def springSecurityService
def someAction = {
def user = springSecurityService.currentUser
…
}
}
В настоящее время я думаю, что способ сделать это:
def user = getAuthenticatedUser()
Вы также можете получить текущего пользователя таким образом
class AnyController {
def springSecurityService
def someAction = {
def user = User.get(springSecurityService.principal.id)
}
}
Используйте этот код:
if (springSecurityService.isLoggedIn()){
println "Logged In"
}