Sa-Token在SpringCloud项目中的应用,admin分配超级权限失败的问题总结

sa-token有权限通配符,

"*":代表拥有所有的权限;

"*:*:*":表示匹配两个冒号间隔三段字符串的权限格式。

权限内容如下:

1.错误的使用:

因为通配符 "*:*:*" 与数据库中的权限名称无法匹配,所以就需要验证了,比如

@SaCheckPermission("GetUsersAsDataSet")。

2.正确做法如下:

perms.add("*");

package org.sharetek.system.service.impl;

import cn.hutool.core.collection.CollUtil;
import cn.hutool.core.convert.Convert;
import cn.hutool.core.lang.tree.Tree;
import cn.hutool.core.util.ObjectUtil;
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
import lombok.RequiredArgsConstructor;
import org.sharetek.common.core.constant.UserConstants;
import org.sharetek.common.core.utils.MapstructUtils;
import org.sharetek.common.core.utils.StreamUtils;
import org.sharetek.common.core.utils.StringUtils;
import org.sharetek.common.core.utils.TreeBuildUtils;
import org.sharetek.common.satoken.utils.LoginHelper;
import org.sharetek.system.domain.SysMenu;
import org.sharetek.system.domain.SysRole;
import org.sharetek.system.domain.SysRoleMenu;
import org.sharetek.system.domain.SysTenantPackage;
import org.sharetek.system.domain.bo.SysMenuBo;
import org.sharetek.system.domain.vo.MetaVo;
import org.sharetek.system.domain.vo.RouterVo;
import org.sharetek.system.domain.vo.SysMenuVo;
import org.sharetek.system.mapper.*;
import org.sharetek.system.service.ISecurityWebApiService;
import org.sharetek.system.service.ISysMenuService;
import org.springframework.stereotype.Service;

import java.util.*;

import static org.sharetek.common.core.constant.UserConstants.SUPER_ADMIN_ROLE_NAME;

/**
* @Description: WebApi 业务层(实现)
* @Param:
* @Return:
* @Author: tjm
* @Date: 2024/2/5 18:01
*/
@RequiredArgsConstructor
@Service
public class SecurityWebApiServiceImpl implements ISecurityWebApiService {

    private final SecurityWebApiMapper securityWebApiMapper;

    private final SecurityRoleMapper securityRoleMapper;

    /**
     * @param userName
     * @Description: 根据用户名查询权限
     * @Param: [userName]
     * @Return: java.util.List<java.lang.String>
     * @Author: tianjunmou
     * @Date: 2024/2/6 10:20
     */
    @Override
    public Set<String> selectPermsByUserName(String userName) {
        Set<String> perms = new HashSet<>();
        List<String> roles = securityRoleMapper.selectRolesByUserName(userName);
        // 管理员角色"Administrators"拥有所有权限
        if (roles.contains(SUPER_ADMIN_ROLE_NAME)) {
            perms.add("*");
        } else {
            perms.addAll(securityWebApiMapper.selectPermsByUserName(userName));
        }
        return perms;
    }
}

 "*"匹配所有的权限内容格式,既然匹配上了,就拥有了权限,所以验证通过。

3.官方参考资料如下:

Sa-TokenSa-Token是一个java权限认证框架,功能全面,上手简单,登录认证、权限认证、Session会话、踢人下线、账号封禁、集成Redis、前后端分离、分布式会话、微服务网关鉴权、单点登录、OAuth2.0、临时Token验证、记住我模式、模拟他人账号、临时身份切换、多账号体系、注解式鉴权、路由拦截式鉴权、花式token、自动续签、同端互斥登录、会话治理、密码加密、jwt集成、Spring集成、WebFlux集成...,有了sa-token,你所有的权限认证问题,都不再是问题icon-default.png?t=N7T8https://sa-token.cc/doc.html#/use/jur-auth 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值