分析AOP 类DataScopeAspect 对于全部权限、自定义权限、仅本人权限最终添加的SQL 语句

目录

1.仅本人权限分析

1.1设置为仅本人权限

1.1.1当前用户权限(本部门数据权限)

 1.1.2 设置用户权限为仅本人数据权限

 1.1.3 我们可以发现当前权限已经改变

 1.2 后端代码分析

2.全部权限分析

2.1设置为全部数据权限

2.1.1设置用户权限为全部数据权限

 2.1.2 我们可以发现当前权限已经改变

 2.2 后端代码分析

3.自定义权限

3.1设置为自定义数据权限

3.1.1设置用户权限为自定义数据权限

 3.1.2 我们可以发现当前权限已经改变​编辑

 3.2后端代码分析


1.仅本人权限分析

1.1设置为仅本人权限

1.1.1当前用户权限(本部门数据权限)

 1.1.2 设置用户权限为仅本人数据权限

 1.1.3 我们可以发现当前权限已经改变

 1.2 后端代码分析

(1)在后端控制台我们可以看到如下的条件筛选,但是在SysUserMapper.xml中的select语句我们只能看到一个筛选条件,但是下面有一个很突兀的“${params.dataScope}”,说明这东西是“and (u.user_id=2)”

 

我们可以看到倒数第二行${params.dataScope}就是对数据范围进行过滤

其中,params指的是parameterType="SysUser"传来的参数 SysUse的一个属性,然后这个属性的dataScope属性。

既然params.dataScope通过占位符嵌入在这里,那么他肯定是一个sql语句。我们返回到sysUser实体类中,发现sysUser中并没有params 这个属性。

这里我们可以看到SysUser继承了BaseEntity,果然我们在BaseEntity这个类中发现了 params 这个属性

public class BaseEntity implements Serializable
{
    private static final long serialVersionUID = 1L;

    /** 搜索值 */
    private String searchValue;

    /** 创建者 */
    private String createBy;

    /** 创建时间 */
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    private Date createTime;

    /** 更新者 */
    private String updateBy;

    /** 更新时间 */
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    private Date updateTime;

    /** 备注 */
    private String remark;

    /** 请求参数 */
    private Map<String, Object> params;

 (2)我们在监测@DataScope 的切面类DataScopeAspect中

    /**
     * 仅本人数据权限
     */
    public static final String DATA_SCOPE_SELF = "5";
            else if (DATA_SCOPE_SELF.equals(dataScope))
            {
                if (StringUtils.isNotBlank(userAlias))
                {
                    sqlString.append(StringUtils.format(" OR {}.user_id = {} ", userAlias, user.getUserId()));
                }
                else
                {
                    // 数据权限为仅本人且没有userAlias别名不查询任何数据
                    sqlString.append(StringUtils.format(" OR {}.dept_id = 0 ", deptAlias));
                }
            }

可以看到因为设置的仅本人权限,执行的是这段代码,等效于or u.user_id =2;

(3)再通过以下代码将   

OR u.user_id = 2  转为 AND (u.user_id = 2)  

if (StringUtils.isNotBlank(sqlString.toString()))
        {
            Object params = joinPoint.getArgs()[0];
            if (StringUtils.isNotNull(params) && params instanceof BaseEntity)
            {
                BaseEntity baseEntity = (BaseEntity) params;
                 baseEntity.getParams().put(DATA_SCOPE, " AND (" + sqlString.substring(4) + ")");
//将完成好的sql语句放在实体类 params的 dataScope属性中 这个属性是一个Map
            }
        }

 (4)返回给最开始那个感觉到突兀的${params.dataScope}中去;

2.全部权限分析

2.1设置为全部数据权限

2.1.1设置用户权限为全部数据权限

 2.1.2 我们可以发现当前权限已经改变

 2.2 后端代码分析

(1)在后端控制台查看,因为是全部权限,所以不会额外添加筛选条件

(2)DataScopeAspect中并未对sql语句做拼接处理

if (DATA_SCOPE_ALL.equals(dataScope))
            {
                sqlString = new StringBuilder();
                break;
            }

 (3)所以${params.dataScope}中并没有内容。

3.自定义权限

3.1设置为自定义数据权限

3.1.1设置用户权限为自定义数据权限

 3.1.2 我们可以发现当前权限已经改变

 3.2后端代码分析

(1)查看控制台 

 (2)在DataScopeAspect中,执行以下代码

else if (DATA_SCOPE_CUSTOM.equals(dataScope))
            {
                sqlString.append(StringUtils.format(
                        " OR {}.dept_id IN ( SELECT dept_id FROM sys_role_dept WHERE role_id = {} ) ", deptAlias,
                        role.getRoleId()));
            }

 (3)   执行以下代码

if (StringUtils.isNotBlank(sqlString.toString()))
        {
            Object params = joinPoint.getArgs()[0];
            if (StringUtils.isNotNull(params) && params instanceof BaseEntity)
            {
                BaseEntity baseEntity = (BaseEntity) params;
                 baseEntity.getParams().put(DATA_SCOPE, " AND (" + sqlString.substring(4) + ")");
//将完成好的sql语句放在实体类 params的 dataScope属性中 这个属性是一个Map
            }
        }

 (4)返回给最开始那个感觉到突兀的${params.dataScope}中去;

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
回答: AOP实现自定义权限注解可以通过使用Spring AOP来实现。首先,你需要定义一个自定义注解,用于标记需要进行权限控制的方法。然后,你可以使用AOP的方式,在方法执行前或执行后进行权限验证。具体实现可以参考以下步骤: 1. 定义自定义注解:你可以使用@PreventRepeat注解来标记需要进行权限控制的方法。 2. 创建切面:你需要创建一个切面,使用@Aspect注解标记,并在该中定义一个切点,用于匹配被@PreventRepeat注解标记的方法。 3. 实现权限验证逻辑:在切面中,你可以使用@Before或@After注解来定义权限验证的逻辑。在方法执行前或执行后,你可以进行相应的权限验证操作。 4. 配置AOP:最后,你需要在Spring配置文件中配置AOP,将切面和切点与目标对象关联起来。 通过以上步骤,你就可以实现自定义权限注解的AOP实现了。这样,在被@PreventRepeat注解标记的方法执行前或执行后,你可以进行相应的权限验证操作。\[1\]\[2\]\[3\] #### 引用[.reference_title] - *1* *2* *3* [java-使用spring AOP实现自定义注解](https://blog.csdn.net/weixin_43846708/article/details/129547120)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值