shiro_动态更新shiro中subject信息

需求:
当前登录用户切换部门之后,更新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中的克隆方法,克隆登录用户大部分信息,毕竟修改只是修改其中一小部分,大部分的值是没有做修改的
这里还涉及到权限的问题,权限的解决办法是有一个单独的接口,前端在成功切换部门之后,会调用查询权限的接口,这里就不贴出来了

©️2020 CSDN 皮肤主题: 技术黑板 设计师:CSDN官方博客 返回首页