gpt4 book ai didi

java - 如何使用 Spring Security 获取 session 超时消息

转载 作者:塔克拉玛干 更新时间:2023-11-03 04:19:51 26 4
gpt4 key购买 nike

我想在 session 过期时获取 session 超时消息。下面是我的spring-security.xml

<http auto-config="true" use-expressions="true">
<logout logout-success-url="/" invalidate-session="true" logout-url="/LogOut"/>
<form-login login-page="/Login" username-parameter="Name" password-parameter="Pwd"/>
<session-management invalid-session-url="/?timeout=true">
<concurrency-control max-sessions="1" expired-url="/Timeout?timeout=true" />
</session-management>
</http>

据我所知,当 session 过期时使用上面的代码,它应该重定向到 /?timeout=true OR/Timeout?timeout=true。在注销时,它应该转到 /。但在我注销的情况下,它还会重定向到 invalid-session-url,所以对于正常注销和 session 超时,我总是会超时。

请帮我区分一下。

更新

/logout请求包含

session = request.getSession();
session.invalidate();
session = null;

最佳答案

我解决了!通过编写过滤器而不是依赖于 Spring-security。

如果有人感兴趣,他们可以使用下面的代码:-

import java.io.IOException;
import java.io.PrintWriter;
import java.io.StringWriter;
import java.text.MessageFormat;

import javax.servlet.FilterChain;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import org.apache.log4j.Logger;
import org.springframework.web.filter.OncePerRequestFilter;

public class FilterToGetTimeOut extends OncePerRequestFilter {

@Override
public void doFilterInternal(HttpServletRequest request, HttpServletResponse response, FilterChain filterChain) throws IOException {
try {
if(request.getRequestURI().equals("/") || request.getRequestURI().equals("/Login/")){
if(request.getSession().getAttribute("login") != null && (Boolean)request.getSession().getAttribute("login") == true){
response.sendRedirect(URL); //After login page
}
} else if(request.getSession().getAttribute("login") == null && !request.getRequestURI().equals("/LogOut")){
response.sendRedirect(request.getContextPath()+"/?timeout=true"); //If timeout is true send session timeout error message to JSP
}
filterChain.doFilter(request, response);
} catch (Exception e) {
//Log Exception

}
}
}

web.xml 中添加这个过滤器。

    <filter>
<filter-name>FilterToGetTimeOut </filter-name>
<filter-class>package.FilterToGetTimeOut </filter-class>
</filter>
<filter-mapping>
<filter-name>FilterToGetTimeOut</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>

所以现在 session 也失效了,我也可以处理 session 超时。

关于java - 如何使用 Spring Security 获取 session 超时消息,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36708580/

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