我正在使用带有 spring-security-core 插件 3.1.2 的 grails 3.2.9。
我已经运行了 s2-quickstart 脚本来创建用户、角色和用户角色域类。我发现 User 和 Role 域中的 id 字段被认为是合成的。例如,如果我运行以下代码,则不会显示 id 字段:
def u = User.class.declaredFields.findAll {!it.synthetic}
u.each {
println it
}
这是我的用户类:
@GrailsCompileStatic
@EqualsAndHashCode(includes='username')
@ToString(includes='username', includeNames=true, includePackage=false)
class User extends BaseDomain implements Serializable {
private static final long serialVersionUID = 1
String username
String password
boolean enabled = true
boolean accountExpired
boolean accountLocked
boolean passwordExpired
Date lastLogin
Set<Role> getAuthorities() {
(UserRole.findAllByUser(this) as List<UserRole>)*.role as Set<Role>
}
static constraints = {
password blank: false, password: true
username blank: false, unique: true
}
static mapping = {
id generator: 'identity', column: 'user_id', sqlType: 'bigint(20) unsigned'
password column: '`password`'
lastLogin sqlType: 'timestamp'
}
}
我的其他域类没有发生这种情况,我看到的第一个问题是 exa-datatables 插件(2.0.1)。该插件使用类似的代码来查找域的字段,因此当请求插件显示 id 字段时,它会失败并出现未知列错误。