需求:
当前登录用户切换部门之后,更新subject中的用户信息,之后通过subject获取登录用户信息,需要是切换部门之后的用户信息
解决:
@ApiOperation(value = "更新用户信息", notes = "更新用户信息")
@GetMapping("/setUser")
public void setUser(@RequestParam("companyIds") String companyIds,
@RequestParam(value = "deptIds", required = false) String deptIds) {
//获取当前登录用户信息
Subject subject = SecurityUtils.getSubject();
ReportUser admin = (ReportUser) subject.getPrincipals().asList().get(0);
//修改后的用户信息
ReportUser newInfo = BeanCloneUtil.jsonClone(admin, ReportUser.class);
newInfo.setCompanyIds(companyIds);
newInfo.setDeptIds(deptIds);
PrincipalCollection principalCollection = subject.getPrincipals();
//realName认证信息的key,对应的value就是认证的user对象
String realmName = principalCollection.getRealmNames().iterator().next();
//创建一个PrincipalCollection对象,newInfo是更新后的ReportUser对象
PrincipalCollection newPrincipalCollection = new SimplePrincipalCollection(newInfo, realmName);
subject.runAs(newPrincipalCollection);
}
这里通过BeanCloneUtil中的克隆方法,克隆登录用户大部分信息,毕竟修改只是修改其中一小部分,大部分的值是没有做修改的
这里还涉及到权限的问题,权限的解决办法是有一个单独的接口,前端在成功切换部门之后,会调用查询权限的接口,这里就不贴出来了