gpt4 book ai didi

java - Spring 安全 : 404 on logout

转载 作者:IT老高 更新时间:2023-10-28 21:17:34 26 4
gpt4 key购买 nike

当我尝试访问我的 spring 应用程序的注销 URL 时,我收到 404 错误并且 在 DispatcherServlet 中找不到带有 URI [/logout] 的 HTTP 请求的映射,名称为“mvc-dispatcher”在我的服务器日志中。

我已经尝试过Call to j_spring_security_logout not working , Issue with Spring security's logout以及几乎所有关于 SO 的相关结果。

我包括完整的配置文件,因为我还不太清楚 Spring xml 结构。

我的安全配置:

<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.2.xsd
http://www.springframework.org/schema/security
http://www.springframework.org/schema/security/spring-security.xsd">

<http pattern="/resources/**" security="none" />

<http auto-config="true">
<intercept-url pattern="/login*" access="IS_AUTHENTICATED_ANONYMOUSLY" />
<intercept-url pattern="/**" access="ROLE_USER" />
<form-login login-page="/login" default-target-url="/"/>
<logout logout-url="/logout" />
<csrf />
</http>

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

<authentication-manager>
<authentication-provider user-service-ref="userDetailsService" />
</authentication-manager>

</beans:beans>

我的 web.xml 是这样的:

<web-app version="2.5" xmlns="http://java.sun.com/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd">

<display-name>XYZ</display-name>

<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>/WEB-INF/spring/*-config.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>mvc-dispatcher</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<load-on-startup>1</load-on-startup>
</servlet>

<servlet-mapping>
<servlet-name>mvc-dispatcher</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
</web-app>

如何使注销页面正常工作?

最佳答案

如果您在 CSRF 中使用注销,则必须执行 POST。见 http://docs.spring.io/spring-security/site/docs/current/reference/htmlsingle/#csrf-logout

关于java - Spring 安全 : 404 on logout,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23187109/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com