提出一个问题:
先解释一些SecurityContextHolder是什么:是SpringSecurity中的一个核心类。
它的作用是:用来管理当前线程的安全上下文对象。
1、提供了方便的方式访问当前线程。——SecurityContextHolder.getContext()
2、提供了可靠方式管理安全上下文对象——内部使用ThreadLocal
3、提供了一种灵活的方式来配置和扩展安全上下文管理机制。
1、SecurityContextHolder类内部可以理解成一个Thread Local集合
2、它是一个静态类,可以用来访问不同线程之间的数据
3、它在ThreadLocal上进行了更高级的封装。
通过前面3点已经可以知道为什么要有ThreadLocal了,再提出一个问题,
回答:
SecurityContextHolder 提供了静态方法 getContext() 和 setContext() 来获取和设置当前线程的安全上下文对象。这里就可以不需要之间操作ThreadLocal了。
会在特定时机自动清空当前线程中的安全上下文对象。
在使用 @Async 注解或使用线程池时,SecurityContextHolder 会在每个任务或线程执行完成后自动清空安全上下文对象,以避免潜在的线程间数据共享问题。
SecurityContextHolder 可以通过配置不同的 SecurityContextHolderStrategy 实现类来支持不同的安全上下文管理策略。默认情况下,它使用 ThreadLocalSecurityContextHolderStrategy,基于 ThreadLocal 来管理安全上下文对象。但也可以根据需要,通过自定义的实现类来支持其他的策略,比如基于 InheritableThreadLocal 或外部存储介质等。
SecurityContextHolder 提供了 clearContext() 方法,用于清空当前线程中的安全上下文对象。这样,在特定的场景下,我们可以手动清空安全上下文对象,以确保及时释放资源或切换用户身份等需求。