【发布时间】:2014-01-02 22:26:05
【问题描述】:
我一直在尝试将 spring-security 集成到我的一个 grails 应用程序中。正如spring security教程中提到的,我使用以下代码安装了插件
BuildConfig.groovy: 我添加了以下代码
repositories {
mavenRepo 'http://repo.spring.io/milestone'
}
plugins {
compile ':spring-security-core:2.0-RC2'
}
后来我清理了代码并编译它以确保下载了依赖项。我还检查了 .grails 文件夹以确保下载了依赖项。
接下来我创建了 User 和 Role 类。 (注意:我将这些类分别命名为 Person 和 Authority)。
在此之后我创建了 SecureController 并且没有添加任何安全访问注释,但我仍然无法访问安全控制器。控件直接重定向到登录控制器
问题 1: 是不是在使用spring security插件后,每个页面都需要认证。有没有办法不用登录就可以访问页面
接下来我将@Secured 注解添加到 SecureController。尽管 @Secured 注释存在于项目的插件文件夹中,但它根本没有被检测到。最初我以为我错过了一些东西,所以我从开始实施相同的步骤再次创建了项目。但是这次插件被检测到了
问题 2: 为什么 spring-security 插件的行为如此不一致
我尝试在不登录的情况下访问 SecureController,我收到以下错误。
EL1008E:(pos 0):在“org.springframework.security.web.access.expression.WebSecurityExpressionRoot”类型的对象上找不到字段或属性“ADMIN_ROLE”
登录并尝试访问控制器后,我也遇到了同样的错误。
问题 3: 是不是我遗漏了需要指定的依赖。
在登录页面中,表单会导致一些操作“j_security_check”。我在任何控制器中都没有注意到这个动作。
问题 4: 我是否需要为这个名称创建一个新操作
请帮我解决这个问题。非常感谢您的帮助。
【问题讨论】:
-
每个问题一个问题:)
-
嗨,Burt,您能告诉我为什么会收到 WebSecurityExpressionRoot 错误。
-
@Rammohan 这是另一个问题(请打开新问题),您需要提供日志信息,我们才能为您提供帮助。
标签: spring grails spring-security grails-plugin grails-2.2