gpt4 book ai didi

java - 如何在 spring security 中正确注销用户

转载 作者:行者123 更新时间:2023-11-29 05:31:43 25 4
gpt4 key购买 nike

编辑 - 1

<security:logout
invalidate-session="true"
logout-success-url="/logout"
logout-url="/logoutfail"/>

</security:http>

编辑 - 1 结束 http://pastie.org/8588538第 1 到 6 行是注销用户的正确方法吗?因为当我这样做时,用户似乎暂时在页面上注销,但随后可以使用相同的登录名再次访问其他页面。似乎第 31 和 38 行正在制作一个新的 session cookie。但是如何呢?

@RequestMapping(value = "/logout" )
public String logout(ModelMap model, HttpServletRequest request){
request.getSession(true).invalidate();
System.out.println("logout user page shown--------------------");
return "/login/logout";
}


200 OK

GET /logout

200 OK

localhost:8080

5.7 KB

127.0.0.1:8080



225ms
HeadersResponseHTMLCacheCookies
Response Headersview source
Content-Language en
Content-Length 5864
Content-Type text/html;charset=ISO-8859-1
Date Mon, 30 Dec 2013 21:38:59 GMT
Server Apache-Coyote/1.1
Set-Cookie JSESSIONID=4B961D14E4B3096368BCC5F9A55874BC; Path=/ttmaven/; HttpOnly

Request Headersview source
Accept text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8
Accept-Encoding gzip, deflate
Accept-Language en-US,en;q=0.5
Connection keep-alive
Cookie JSESSIONID=A0E89C909D0A7F7BE93EC737130E9A31
Host localhost:8080
Referer http://localhost:8080/ttmaven/users/home
User-Agent Mozilla/5.0 (X11; Ubuntu; Linux x86_64; rv:25.0) Gecko/20100101 Firefox/25.0

最佳答案

这是你的做法:

SecurityContextHolder.getContext().setAuthentication(null);

Spring Security 还带有已经实现的登录/注销功能,这里是您如何配置自定义注销 URL。那时您不必创建任何 Controller /请求映射。

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

<http auto-config="true" use-expressions="true">
<logout logout-url="/custom_logout_url" />
</http>
</beans:beans>

关于java - 如何在 spring security 中正确注销用户,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20848312/

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