我使用Spring Security的核心在我的web應用程序的認證,但我無法弄清楚如何從我的User類 得到一個定製的信息,這裏是我的用戶等級:Grails Spring Security核心 - 自定義用戶信息?
package core
import beans.Colaborador
import groovy.transform.EqualsAndHashCode
import groovy.transform.ToString
@EqualsAndHashCode(includes = 'username')
@ToString(includes = 'username', includeNames = true, includePackage = false)
class Usuario implements Serializable {
private static final long serialVersionUID = 1
transient springSecurityService
String username
String password
boolean enabled = true
boolean accountExpired
boolean accountLocked
boolean passwordExpired
Colaborador colaborador
Usuario(String username, String password) {
this()
this.username = username
this.password = password
}
Set<Permissao> getAuthorities() {
UsuarioPermissao.findAllByUsuario(this)*.permissao
}
def beforeInsert() {
encodePassword()
}
def beforeUpdate() {
if (isDirty('password')) {
encodePassword()
}
}
protected void encodePassword() {
password = springSecurityService?.passwordEncoder ? springSecurityService.encodePassword(password) : password
}
static transients = ['springSecurityService']
static constraints = {
username blank: false, unique: true
password blank: false
colaborador nullable: true
}
static mapping = {
password column: '`password`'
}
}
我想要的信息如果我嘗試通過使用秒來訪問它:loggedInUserInfo並沒有成功,我讀過我需要創建一個自定義UserDetailsService,但我無法找出如何以及在哪裏創造它,可以有人給我一隻手嗎?
謝謝!
@Edit
我試過下面的文檔和我創建兩個類
import beans.Colaborador
import grails.plugin.springsecurity.userdetails.GrailsUser
import org.springframework.security.core.GrantedAuthority
class MyUserDetails extends GrailsUser {
final Colaborador colaborador
MyUserDetails(String username, String password, boolean enabled,
boolean accountNonExpired, boolean credentialsNonExpired,
boolean accountNonLocked,
Collection<GrantedAuthority> authorities,
long id, Colaborador colaborador) {
super(username, password, enabled, accountNonExpired,
credentialsNonExpired, accountNonLocked, authorities, id)
this.colaborador = colaborador
}
}
和
package core
import grails.plugin.springsecurity.SpringSecurityUtils
import grails.plugin.springsecurity.userdetails.GrailsUserDetailsService
import grails.plugin.springsecurity.userdetails.NoStackUsernameNotFoundException
import grails.transaction.Transactional
import org.springframework.security.core.authority.SimpleGrantedAuthority
import org.springframework.security.core.userdetails.UserDetails
import org.springframework.security.core.userdetails.UsernameNotFoundException
class MyUserDetailsService implements GrailsUserDetailsService {
static final List NO_ROLES = [new SimpleGrantedAuthority(SpringSecurityUtils.NO_ROLE)]
UserDetails loadUserByUsername(String username, boolean loadRoles)
throws UsernameNotFoundException {
return loadUserByUsername(username)
}
@Transactional(readOnly = true, noRollbackFor = [IllegalArgumentException, UsernameNotFoundException])
UserDetails loadUserByUsername(String username) throws UsernameNotFoundException {
Usuario user = Usuario.findByUsername(username)
if (!user) throw new NoStackUsernameNotFoundException()
def roles = user.authorities
def authorities = roles.collect {
new SimpleGrantedAuthority(it.authority)
}
return new MyUserDetails(user.username, user.password, user.enabled,
!user.accountExpired, !user.passwordExpired,
!user.accountLocked, authorities ?: NO_ROLES, user.id,
user.colaborador)
}
}
,當我在我的應用登錄我得到這個錯誤:
2016-11-14 11:56:46,061 [http-bio-80-exec-4] ERROR authentication.GrailsUsernamePasswordAuthenticationFilter - An internal error occurred while trying to authenticate the user.
Message: Could not find matching constructor for: java.lang.Object(java.lang.String, java.lang.String, java.lang.Boolean, java.lang.Boolean, java.lang.Boolean, java.lang.Boolean, java.util.ArrayList, java.lang.Long)
你只是想要訪問用戶類通知到另一種方法或類權利? –
我想從另一個類或視圖訪問自定義的用戶信息,在這種情況下,來自該Colaborador對象的數據 – xSlok