2

我正在使用 Spring 3.1 和 Spring Security 3.1 和 JBoss EAP 6。

我一直在尝试使用 Spring security @Secured 注解,但它不起作用。我认为我做对了,但显然有些地方是错的。

我已经在类、方法上尝试过@Secured,但我真正想要的地方是在接口上,这就是它在 Spring 文档中的说明。

spring-security.xml 文件:

    <?xml version="1.0" encoding="UTF-8"?>
    <beans xmlns="http://www.springframework.org/schema/beans"
            xmlns:security="http://www.springframework.org/schema/security" 
            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/context   
                                http://www.springframework.org/schema/context/spring-context-3.0.xsd
                                http://www.springframework.org/schema/mvc       
                                http://www.springframework.org/schema/mvc/spring-mvc-3.0.xsd
                                http://www.springframework.org/schema/security  
                                http://www.springframework.org/schema/security/spring-security-3.1.xsd">

        <security:global-method-security secured-annotations="enabled" />

        <security:http auto-config="true">
        <!-- Restrict URLs based on role -->
        <security:intercept-url pattern="/test/login*" access="IS_AUTHENTICATED_ANONYMOUSLY" />
        <security:intercept-url pattern="/test/logoutSuccess*" access="IS_AUTHENTICATED_ANONYMOUSLY" />
        <security:intercept-url pattern="/css/**" access="IS_AUTHENTICATED_ANONYMOUSLY" />
        <security:intercept-url pattern="/images/**" access="IS_AUTHENTICATED_ANONYMOUSLY" />
        <security:intercept-url pattern="/js/**" access="IS_AUTHENTICATED_ANONYMOUSLY" />
        <security:intercept-url pattern="/**" access="ROLE_USER, ROLE_ADMIN" />
        <security:intercept-url pattern="/test/admin**" access="ROLE_ADMIN" />      

        <!-- Override default login and logout pages -->
        <security:form-login login-page="/test/login" 
                     login-processing-url="/j_spring_security_check" 
                     default-target-url="/test/testHome" 
                     authentication-failure-url="/test/loginfailed" />
        <security:logout invalidate-session="true" logout-success-url="/test/logout" />
        </security:http>

        <security:authentication-manager>
            <security:authentication-provider>
                <security:user-service>
                    <security:user name="test_user" password="test" authorities="ROLE_ADMIN" />
                    <security:user name="test_admin" password="admin" authorities="ROLE_USER" />
                </security:user-service>
            </security:authentication-provider>
        </security:authentication-manager>

    </beans>

春天.xml

    <?xml version="1.0" encoding="UTF-8"?>
    <beans xmlns="http://www.springframework.org/schema/beans"
        xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
        xmlns:jdbc="http://www.springframework.org/schema/jdbc"
        xmlns:tx="http://www.springframework.org/schema/tx"
        xmlns:p="http://www.springframework.org/schema/p"
        xmlns:context="http://www.springframework.org/schema/context"
        xsi:schemaLocation="http://www.springframework.org/schema/beans
                                http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
                                http://www.springframework.org/schema/jdbc
                                http://www.springframework.org/schema/jdbc/spring-jdbc-3.0.xsd
                                http://www.springframework.org/schema/tx
                                http://www.springframework.org/schema/tx/spring-tx-3.0.xsd
                                http://www.springframework.org/schema/context
                                http://www.springframework.org/schema/context/spring-context-3.0.xsd">

        <context:annotation-config/>    
        <context:component-scan base-package="com.test.service"/>

    </beans>

mvc-config.xml

    <?xml version="1.0" encoding="UTF-8"?>
    <beans xmlns="http://www.springframework.org/schema/beans"
        xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
        xmlns:context="http://www.springframework.org/schema/context"
        xmlns:mvc="http://www.springframework.org/schema/mvc"
        xsi:schemaLocation="http://www.springframework.org/schema/beans   http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
                http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.0.xsd
                http://www.springframework.org/schema/mvc     http://www.springframework.org/schema/mvc/spring-mvc-3.0.xsd">

        <context:component-scan base-package="com.test.service"/>

        <mvc:annotation-driven/>

        <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
            <property name="prefix" value="/WEB-INF/views/"/>
            <property name="suffix" value=".jsp"/>
        </bean>

        <bean id="messageSource" class="org.springframework.context.support.ResourceBundleMessageSource">
            <property name="basenames">
                <list>
                    <value>mymessages</value>
                </list>
            </property>
        </bean>

    </beans>

客户端配置.xml

    <?xml version="1.0" encoding="UTF-8"?>
    <beans xmlns="http://www.springframework.org/schema/beans"
        xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
        xmlns:oxm="http://www.springframework.org/schema/oxm"
        xsi:schemaLocation="http://www.springframework.org/schema/beans 
                            http://www.springframework.org/schema/beans/spring-beans.xsd
                    http://www.springframework.org/schema/oxm 
                    http://www.springframework.org/schema/oxm/spring-oxm-3.0.xsd">

        <oxm:jaxb2-marshaller id="marshaller" contextPath="com.test.service.ws" />

        <bean class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
            <property name="location">
                <value>classpath:/environment.properties</value>
            </property>
        </bean>

        <bean id="webServiceTemplate" class="org.springframework.ws.client.core.WebServiceTemplate">
            <property name="marshaller" ref="marshaller" />
            <property name="unmarshaller" ref="marshaller" />
            <property name="defaultUri" value="${test.webServiceTemplate.defaultUri}" />
        </bean>

        <bean class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
            <property name="location">
                <value>classpath:/activedirectory.properties</value>
            </property>
        </bean>

        <bean id="ldapActiveDirectoryAuthProvider" class="org.springframework.security.ldap.authentication.ad.ActiveDirectoryLdapAuthenticationProvider">
            <constructor-arg value="${test.activeDirectory.domain}" />
            <constructor-arg value="${test.activeDirectory.activeDirectoryServer}" />
            <property name="userDetailsContextMapper" ref="tdrUserDetailsContextMapper" /> 
            <property name="useAuthenticationRequestCredentials" value="true" />        
            <property name="convertSubErrorCodesToExceptions" value="true"/>
        </bean>  

        <bean id="tdrUserDetailsContextMapper" class="com.test.service.web.user.impl.UserDetailsContextMapperImpl" />   

    </beans>

我的界面之一

import org.springframework.security.access.annotation.Secured;

public interface TestService {

    @Secured ({"ROLE_XXX"})
    TestResponse getCustomer(TestRequest request);

}
4

0 回答 0