Spring Security Method Level Security Annotations NOT working
我正在使用 Struts 2 Spring Security 3 制作一个简单的 Web 应用程序。我想使用 Pre-Post Annotations 来实现方法级别的安全性。
但是注释不起作用。
这是我的 web.xml
1
2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 |
<?xml version=”1.0″ encoding=”UTF-8″?>
<web-app xmlns:xsi=”http://www.w3.org/2001/XMLSchema-instance” xmlns=”http://java.sun.com/xml/ns/javaee” xmlns:web=”http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd” xsi:schemaLocation=”http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd” id=”WebApp_ID” version=”2.5″> <display-name>MyCustomSpringSecurity</display-name> <context-param> <listener> <filter> <filter-mapping> <filter-mapping> |
这是我的 struts.xml
1
2 3 4 5 6 7 8 9 |
<?xml version=”1.0″ encoding=”UTF-8″?>
<!DOCTYPE struts PUBLIC”-//Apache Software Foundation//DTD Struts Configuration 2.1//EN””http://struts.apache.org/dtds/struts-2.1.dtd”> <struts> <package name=”default” extends=”struts-default”> <result name=”success”>/firstPage.jsp</result> </action> </package> </struts> |
这是我的 applicationContext.xml
1
2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 |
<?xml version=”1.0″ encoding=”UTF-8″?>
<beans:beans xmlns=”http://www.springframework.org/schema/security” xmlns:beans=”http://www.springframework.org/schema/beans” xmlns:xsi=”http://www.w3.org/2001/XMLSchema-instance” xsi:schemaLocation=”http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd http://www.springframework.org/schema/security http://www.springframework.org/schema/security/spring-security-3.1.xsd”> <global-method-security pre-post-annotations=”enabled”> <beans:bean id=”myAction” class=”code.action.MyAction”> <http auto-config=”true” use-expressions=”true”> </beans:beans> |
最后这是 MyAction.java
1
2 3 4 5 6 7 8 9 10 11 |
package code.action;
import org.springframework.security.access.prepost.PreAuthorize; public class MyAction { |
您可以清楚地看到我为用户分配的角色是 ROLE_USER 但我希望在访问该方法时它是 ROLE_ADMIN ,因此从逻辑上讲,运行此代码时应该出现 403 Access Denied 错误。但它能够访问该方法并显示下一页。
所以我认为注释不起作用。
任何人都知道发生了什么事吗?
- 请做一个测试。创建一个新的 SecuredAction 类并将带有 @PreAuthorize 注释的方法放在此类中。然后在 MyAction 中注入该 bean,并从 showPage 方法调用它。
- 我按你说的试过了。我创建了一个新的 SecuredAction 类并将我的 @PreAuthorize 注释放在该类中,然后创建 SecuredAction 对象并从 MyAction 调用它的方法:showPage() 但仍然无法正常工作。或者我应该尝试使用 Spring Dependency Injection 注入 SecuredAction 的对象,但我认为这将是一回事。
- 是的,您必须使用注射。 — 我已经在我的评论中提到了它(“然后在 MyAction 中注入那个 bean”)。 — 原因是 Spring AOP 只对 Spring Beans 有效,对普通实例无效。
- 感谢你的关心。我唯一缺少的是注入豆子。现在我使用了 Spring 依赖注入,它工作正常。无需创建新的 SecuredAction。
- 你能帮我解决这个问题吗:stackoverflow.com/questions/8208501/…
为了使 Spring 注释在 Struts 2 动作中有意义,您必须使用 Struts 2 Spring 插件。这将使用 Spring 实例化 Struts 2 对象,允许注释处理、注入等。
- 谢谢。这是我让 Spring DI 工作所缺少的。
- 你能帮我解决这个问题吗:stackoverflow.com/questions/8208501/…
我们不能像这样直接使用Spring注解。
还有另一个插件 Struts 2 – Spring Plugin 用于相同目的。您可以从链接下载 jar 文件并将其包含在您的项目中。
- 感谢您提供最新的工作链接,因为旧链接已被删除。
来源:https://www.codenong.com/8179171/