当我尝试在@Secured注释之外定义我的String时,我在grails中得到以下错误。
我得到以下错误Role.USER'是一个java.lang.String类型的内联常量,而不是@ grails.plugin.springsecurity.annotation.Secured中的属性表达式
class Role {
final static String USER = "ROLE_USER"
final static String ADMIN = "ROLE_ADMIN"
public final static String[] LOGINED_USER = [USER, ADMIN].asImmutable()
}
以下控制器说明了我的问题..
class MyController {
@Secured(["permitAll"]) //Works fine
def action1() {
}
@Secured(LOGINED_USER) //Doesn't work
def action2() {
}
@Secured([Role.ADMIN, Role.USER]) //Doesn't work
def action3() {
}
@Secured(["ROLE_ADMIN", "ROLE_USER"]) //Works fine
def action4() {
}
}
您必须明确公开USER和ADMIN常量,添加public
修饰符
public final static String USER = "ROLE_USER"
public final static String ADMIN = "ROLE_ADMIN"
在这种情况下,Groovy不会使用注释中不允许使用的geters
setter
。