关于shiro授权的格式记录

    @Bean
    public ShiroFilterFactoryBean shiroFilterFactoryBean(SecurityManager securityManager) {
        ShiroFilterFactoryBean shiroFilterFactoryBean = new ShiroFilterFactoryBean();
        shiroFilterFactoryBean.setSecurityManager(securityManager);
        // 登录
        shiroFilterFactoryBean.setLoginUrl("/login");
        // 首页
        shiroFilterFactoryBean.setSuccessUrl("/index");
        // 错误页面,认证不通过跳转,没有权限的页面
        shiroFilterFactoryBean.setUnauthorizedUrl("/err");

        Map<String, String> map = new LinkedHashMap<>();
        // 以下页面、接口可以直接访问,不需要登录
        // 登出
        map.put("/logout", "logout");
        map.put("/login.jsp", "anon");
        map.put("/login", "anon");
        // xzq添加
        map.put("/css/**", "anon");
        map.put("/fonts/**", "anon");
        map.put("/img/**", "anon");
        map.put("/js/**", "anon");
        map.put("/lib/**", "anon");
        
        // 以下资源需要授权
        List<APermission> list = permissionMapper.list();
        // 格式: 资源:权限名称     /user/list : perms[user:list]
        for (APermission permission : list) {
            map.put(permission.getMethodFullName(), "perms[" + permission.getPermissionName() + "]");
        }
        map.put("/iot_add_datatemplate", "perms[user:d]");
        
        // 所有的资源都需要登录
        map.put("/**", "authc");

        shiroFilterFactoryBean.setFilterChainDefinitionMap(map);
        return shiroFilterFactoryBean;
    }

 

    /**
     * 授权
     */
    @Override
    protected AuthorizationInfo doGetAuthorizationInfo(PrincipalCollection principals) {
        // 保存该用户名拥有的权限,可以保存为全局常量,用户名
        String username = (String) principals.getPrimaryPrincipal();
        // 授权信息
        SimpleAuthorizationInfo info = new SimpleAuthorizationInfo();
        // 判断该用户在Redis中是否有相应的角色,判断该用户在Redis中是否有相应的权限
        Set<String> roleList = RedisUtils.getSet(role_username);
        Set<String> permissionsSet = RedisUtils.getSet(auth_username);

        if (!permissionsSet.isEmpty() && !roleList.isEmpty()) {
            // 赋予角色
            info.addRoles(roleList);
            // 赋予权限
            info.addStringPermissions(permissionsSet);
            return info;
        }
        // 通过用户名到数据库查询用户所拥有的角色
        Set<String> roles = roleMapper.getByUsername(username);
        RedisUtils.setSet(role_username, roles, 30);
        // 通过用户名到数据库查询用户所拥有的角色,角色所拥有的权限(资源) 权限名称
        Set<String> permissions = permissionMapper.getPermissionNameByUsername(username);
        // 格式
        permissions.add("user:a");
        RedisUtils.setSet(auth_username, permissions, 30);
        // 授权信息
        // 将角色赋予用户
        info.addRoles(roles);
        // 将权限赋予角色
        info.addStringPermissions(permissions);
        
        return info;
    }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值