springboot用户创建的业务数据只能是同一组织能看的见

简介: springboot用户创建的业务数据只能是同一组织能看的见

业务场景需求说明:

在项目权限框架体系下。A部门用户 :A张三,创建一条业务单据 :业务单据A数据,

此时呢,业务需求是:【业务单据A数据】只能是 【A部门】下的所有用户能看的见,其他组织无权查看  此条数据

1.数据库设计:

创建:create_dept 字段,记录数据的来源 组织

image.png

  1. 使用SpringAop 技术,将 组织数据过滤 与 业务逻辑隔离。。。

package com.AAA.framework.aspectj;

import com.AAA.common.annotation.BranchScope;
import com.AAA.common.core.domain.BaseEntity;
import com.AAA.common.core.domain.entity.SysUser;
import com.AAA.common.core.domain.model.LoginUser;
import com.AAA.common.utils.SecurityUtils;
import com.AAA.common.utils.StringUtils;
import org.aspectj.lang.JoinPoint;
import org.aspectj.lang.Signature;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Before;
import org.aspectj.lang.annotation.Pointcut;
import org.aspectj.lang.reflect.MethodSignature;
import org.springframework.stereotype.Component;

import java.lang.reflect.Method;

/**

  • 组织数据过滤处理
    *
  • @author wangwei
    */
    @Aspect
    @Component
    public class BranchScopeAspect {

    /* 数据权限过滤关键字 /
    public static final String DATA_SCOPE = "branchScope";

    // 配置织入点
    @Pointcut("@annotation(com.ruoyi.common.annotation.BranchScope)")
    public void branchScopePointCut() {}

    @Before("branchScopePointCut()")
    public void doBefore(JoinPoint point) throws Throwable {
    handleDataScope(point);
    }

    protected void handleDataScope(final JoinPoint joinPoint) {
    // 获得注解
    BranchScope controllerBranchScope = getAnnotationLog(joinPoint);
    if (controllerBranchScope == null) {
    return;
    }
    // 获取当前的用户
    LoginUser loginUser = SecurityUtils.getLoginUser();
    if (StringUtils.isNotNull(loginUser)) {
    SysUser currentUser = loginUser.getUser();
    // 如果是超级管理员,则不过滤数据 && !currentUser.isAdmin()
    if (StringUtils.isNotNull(currentUser) && !currentUser.isAdmin()) {

     branchScopeFilter(joinPoint, currentUser);
    

    }
    }
    }

    /**

    • 数据范围过滤
      *
    • @param joinPoint 切点
    • @param user 用户
      */
      public static void branchScopeFilter(JoinPoint joinPoint, SysUser user) {
      Object params = joinPoint.getArgs()[0];
      if (StringUtils.isNotNull(params) && params instanceof BaseEntity) {
      BaseEntity baseEntity = (BaseEntity) params;
      baseEntity
       .getParams()
           .put(
                   DATA_SCOPE,
                   " AND create_dept IN (SELECT dept_id FROM sys_dept WHERE dept_id = '"
                           + user.getDeptId()
                           + "') ");
      
      }
      }

    /* 是否存在注解,如果存在就获取 /
    private BranchScope getAnnotationLog(JoinPoint joinPoint) {
    Signature signature = joinPoint.getSignature();
    MethodSignature methodSignature = (MethodSignature) signature;
    Method method = methodSignature.getMethod();
    if (method != null) {
    return method.getAnnotation(BranchScope.class);
    }
    return null;
    }
    }

核心关键点说明: 这里处理 过滤组织数据的 思路是,在查询数据的时候,通过 组织id:dept_id ,查询所有业务单据中 有没有 当前登录组织 创建的单据

完整sql语句:

  SELECT count(0) FROM table_aaa   WHERE create_dept IN (SELECT dept_id FROM sys_dept WHERE dept_id = '103')
  1. 详细业务使用:

image.png
自定义注解:

package com.AAA.common.annotation;

import java.lang.annotation.*;

/* 组织过滤注解 /

/*

  • wangwei
  • 2023-05-19 09:08:00
    */
    @Target(ElementType.METHOD)
    @Retention(RetentionPolicy.RUNTIME)
    @Documented
    public @interface BranchScope {}

3.mybatis中配置

${params.branchScope}





<select id="selectJcryList" parameterType="Jcry" resultMap="JcryResult">
    <include refid="selectJcryVo"/>
    <where>
        <if test="name != null  and name != ''"> and name like concat('%', #{name}, '%')</if>
        <if test="pnumber != null  and pnumber != ''"> and pnumber = #{pnumber}</if>
        <if test="deleted != null  and deleted != ''"> and deleted = #{deleted}</if>
        ${params.branchScope}
    </where>
</select>
相关文章
|
5天前
|
Java
Springboot 导出word,动态填充表格数据
Springboot 导出word,动态填充表格数据
|
5天前
|
JSON JavaScript 前端开发
解决js中Long类型数据在请求与响应过程精度丢失问题(springboot项目中)
解决js中Long类型数据在请求与响应过程精度丢失问题(springboot项目中)
48 0
|
5天前
|
存储 搜索推荐 Java
|
5天前
|
数据采集 存储 缓存
SpringBoot与布隆过滤器的完美邂逅:高效防护大规模数据的奇妙结合【实战】
SpringBoot与布隆过滤器的完美邂逅:高效防护大规模数据的奇妙结合【实战】
124 0
|
4天前
|
SQL Java 调度
SpringBoot使用@Scheduled定时任务录入将要过期任务数据
SpringBoot使用@Scheduled定时任务录入将要过期任务数据
|
5天前
|
前端开发 关系型数据库 MySQL
SpringBoot-----从前端更新数据到MySql数据库
SpringBoot-----从前端更新数据到MySql数据库
13 1
|
5天前
|
JSON JavaScript Java
从前端Vue到后端Spring Boot:接收JSON数据的正确姿势
从前端Vue到后端Spring Boot:接收JSON数据的正确姿势
26 0
|
5天前
|
SQL Java 数据库连接
Springboot框架整合Spring JDBC操作数据
JDBC是Java数据库连接API,用于执行SQL并访问多种关系数据库。它包括一系列Java类和接口,用于建立数据库连接、创建数据库操作对象、定义SQL语句、执行操作并处理结果集。直接使用JDBC涉及七个步骤,包括加载驱动、建立连接、创建对象、定义SQL、执行操作、处理结果和关闭资源。Spring Boot的`spring-boot-starter-jdbc`简化了这些步骤,提供了一个在Spring生态中更便捷使用JDBC的封装。集成Spring JDBC需要添加相关依赖,配置数据库连接信息,并通过JdbcTemplate进行数据库操作,如插入、更新、删除和查询。
|
5天前
|
SQL Java 数据库连接
Springboot框架整合Spring Data JPA操作数据
Spring Data JPA是Spring基于ORM和JPA规范封装的框架,简化了数据库操作,提供增删改查等接口,并可通过方法名自动生成查询。集成到Spring Boot需添加相关依赖并配置数据库连接和JPA设置。基础用法包括定义实体类和Repository接口,通过Repository接口可直接进行数据操作。此外,JPA支持关键字查询,如通过`findByAuthor`自动转换为SQL的`WHERE author=?`查询。
|
5天前
|
Java 数据库连接 数据库
【SpringBoot系列】微服务数据持久化方案
【4月更文挑战第8天】微服务数据持久化方案Spring Boot JPA + Hiberate
18 0