使用 Spring-Session 时更新 Session 中的主体

nsd*_*div 4 spring spring-security spring-session

我们用我们自己的 User 对象扩展了主体。这样,该对象对于每个请求都是可用的。当用户更新其信息时,主体需要使用这些新数据进行更新。当不使用 spring-session 时,此方法有效。然而,对于 spring-session 来说,情况并非如此。

我检查了 spring-session 代码,以及RedisOperationsSessionRepository:save(RedisSession session)唯一的调用session.saveDelta(),它仅保存更改的属性。那么,我们如何在会话中更新主体呢?

注意 - 更新主体的地方位于服务层,因此我们无权访问SessionAuthenticationStrategy.

nsd*_*div 8

找到了一种方法来做到这一点,所以回答我自己的问题。Spring-security 将上下文存储为HttpSessionSecurityContextRepository.SPRING_SECURITY_CONTEXT_KEY. 因此,手动更新密钥(而不是通过 Spring-Session)会导致主体被更新。

httpSession.setAttribute(
  HttpSessionSecurityContextRepository.SPRING_SECURITY_CONTEXT_KEY,
  SecurityContextHolder.getContext()
);
Run Code Online (Sandbox Code Playgroud)