SpringBoot整合shiro-用户授权时遇到的问题:java.lang.ClassCastException

本文介绍了一种在Shiro框架中进行权限和角色配置的方法。通过将Principal对象转换为User对象,然后利用BeanUtils.copyProperties方法进行属性复制,实现了从数据库中查找角色和权限并将其添加到AuthorizationInfo中。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

解决方式:在授权的方法里面,把principal.getPrimaryPrincipal()获取到的对象复制给User就行了!

Object obj = principal.getPrimaryPrincipal();
        User user = new User();
        BeanUtils.copyProperties(obj,user);
// 授权
    @Override
    protected AuthorizationInfo doGetAuthorizationInfo(PrincipalCollection principal) {
        SimpleAuthorizationInfo authorizationInfo = new SimpleAuthorizationInfo();
        Object obj = principal.getPrimaryPrincipal();
        User user = new User();
        BeanUtils.copyProperties(obj,user);
        sysRoleMapper.findRoleByUsername(user.getEmail()).stream().forEach(sysRole -> {
            // 添加角色
            authorizationInfo.addRole(sysRole.getRole());
            sysPermissionMapper.findPermissionByRoleId(sysRole.getId()).stream().forEach(sysPermission -> {
                authorizationInfo.addStringPermission(sysPermission.getPermission());
            });
        });
        return authorizationInfo;
    }

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值