没有为 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 文件中,它将在过滤器实例化时不可用 ...
此致,
洛伊克
我正在尝试使用 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 文件中,它将在过滤器实例化时不可用 ...
此致,
洛伊克