我正在使用javax.servlet.http.HttpSessionListener
类在Spring Boot应用程序中侦听会话更改
public interface HttpSessionListener extends EventListener {
default void sessionCreated(HttpSessionEvent se) {
}
default void sessionDestroyed(HttpSessionEvent se) {
}
}
问题是,如何从
HttpSessionEvent
检索用户信息?我想在会话销毁后删除用户上传的所有文件,这就是为什么我至少需要他的ID
最佳答案
默认情况下,Spring Security在SecurityContext
定义的密钥下将HttpSessionSecurityContextRepository.SPRING_SECURITY_CONTEXT_KEY
存储在会话中。因此,如果用户仍在登录,则可以执行以下操作:
@Override
void sessionDestroyed(HttpSessionEvent se) {
HttpSession session = se.getSession();
SecurityContext context = (SecurityContext) session.getAttribute
(HttpSessionSecurityContextRepository.SPRING_SECURITY_CONTEXT_KEY);
Authentication authentication = context.getAuthentication();
// drill down from here, but could be authentication.getName()
}