没有为 spring restful Web 服务身份验证定义名为 'springSecurityFilterChain' 的 bean 异常

No bean named 'springSecurityFilterChain' is defined exception for spring restful web-service authentication

我正在尝试使用 spring 在我的 Web 服务中添加身份验证。 我已经参考了 this resource 示例代码。 但不幸的是,我遇到了一个例外。

org.springframework.beans.factory.NoSuchBeanDefinitionException: No bean named 'springSecurityFilterChain' is defined

我在 google 上浏览了很多参考资料。但我没有找到任何解决方案。那么任何人都可以提出我在这里做错的任何解决方案吗?

我正在使用以下配置。

Spring 版本 - 3.1.1

应用程序上下文 - web.xml

<context-param>
    <param-name>contextConfigLocation</param-name>
    <param-value>
        /WEB-INF/applicationContext.xml
    </param-value>
</context-param>

<listener>
    <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>

<filter>
    <filter-name>springSecurityFilterChain</filter-name>
    <filter-class>org.springframework.web.filter.DelegatingFilterProxy</filter-class>
</filter>
<filter-mapping>
    <filter-name>springSecurityFilterChain</filter-name>
    <url-pattern>/*</url-pattern>
</filter-mapping>

<servlet>
    <servlet-name>dispatcher</servlet-name>
    <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
    <load-on-startup>2</load-on-startup>
</servlet>
<servlet-mapping>
    <servlet-name>dispatcher</servlet-name>
    <!--<url-pattern>/*</url-pattern>-->
    <url-pattern>*.htm</url-pattern>
</servlet-mapping>
<session-config>
    <session-timeout>
        30
    </session-timeout>
</session-config>
<welcome-file-list>
    <welcome-file>redirect.jsp</welcome-file>
</welcome-file-list>

调度员-servlet.xml

<mvc:annotation-driven/>

<context:annotation-config/>

<context:component-scan base-package="com.em.yms.*" />

<import resource="spring-security.xml"/>

<bean id="urlMapping" class="org.springframework.web.servlet.handler.SimpleUrlHandlerMapping">
    <property name="mappings">
        <props>
            <prop key="index.htm">indexController</prop>
        </props>
    </property>
</bean>


<bean id="viewResolver"
      class="org.springframework.web.servlet.view.InternalResourceViewResolver"
      p:prefix="/WEB-INF/jsp/"
      p:suffix=".jsp" />

<bean name="indexController"
      class="org.springframework.web.servlet.mvc.ParameterizableViewController"
      p:viewName="index" />

spring-security.xml

<http auto-config="true">
    <intercept-url pattern="/**" access="ROLE_USER" />
</http>

<authentication-manager alias="authenticationManager">
    <authentication-provider>
        <user-service id="authenticationService">
            <user name="user" password="123456" authorities="ROLE_USER"/>
        </user-service>
    </authentication-provider>
</authentication-manager> 

可能您的导入不工作。尝试像这样导入 security.xml:

<import resource="classpath:/spring-security.xml"/>

尝试将您的 spring-security.xml 文件导入您的 application.xml 文件或您的分派 -servlet.xml 文件。

我认为问题出在上下文文件的加载顺序上。在J2EE容器中,加载的顺序是listener、filter、server。当您的应用程序上下文文件由侦听器加载时,它将在 spring 安全过滤器之前加载。但是由于调度程序 servlet 在过滤器之后加载,如果您将 spring 安全文件导入它的 dispatched-servlet.xml 文件中,它将在过滤器实例化时不可用 ...

此致,

洛伊克