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