spring security如何实现用户权限动态刷新?
是用户权限的动态刷新,就是用户的权限被更改了,那么登陆中的用户权限也会被更改,包括用户的密码,权限信息,是需要修改user-service吗?...
是用户权限的动态刷新,就是用户的权限被更改了,那么登陆中的用户权限也会被更改,包括用户的密码,权限信息,是需要修改user-service吗?
展开
1个回答
展开全部
可以修改user-service,但不要用认证管理器调用了,自己调用。
认证管理器在认证时通过user-service把权限信息加载到内存中,修改后可通过SecurityContextHolder.getContext().getAuthentication()和setAuthentication(authentication)访问权限。
认证管理器在认证时通过user-service把权限信息加载到内存中,修改后可通过SecurityContextHolder.getContext().getAuthentication()和setAuthentication(authentication)访问权限。
更多追问追答
追问
有两个问题。
getAuthentication获取到的是此次访问的用户的信息,那么我需要做的是修改别人的权限,怎么做?
Authentication是个接口,那么Security保存的实现类是哪个?
追答
这个问题有点儿复杂
2. Authentication的实现类有很多,如:CasAuthenticationToken, JaasAuthenticationToken, UsernamePasswordAuthenticationToken,取决于你的认证方式。如果使用DaoAuthenticationProvider,就用UsernamePasswordAuthenticationToken实现类。如果所有权
1. 列表同时改,就直接setAuthentication整体改。
可以直接参考AbstractUserDetailsAuthenticationProvider的实现方法,直接new出一个。
protected Authentication createSuccessAuthentication(Object principal, Authentication authentication,
UserDetails user) {
UsernamePasswordAuthenticationToken result = new UsernamePasswordAuthenticationToken(principal,
authentication.getCredentials(), authoritiesMapper.mapAuthorities(user.getAuthorities()));
result.setDetails(authentication.getDetails());
return result;
}
Spring Security只是提供了一种安全控制的解决方案,根据实际应用不同具体实现细节都需要改的。
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询