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

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

业务场景需求说明:

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

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

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);
    
    AI 代码解读

    }
    }
    }

    /**

    • 数据范围过滤
      *
    • @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()
                           + "') ");
      
      AI 代码解读
      }
      }

    /* 是否存在注解,如果存在就获取 /
    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')
AI 代码解读
  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>
AI 代码解读
目录
打赏
0
1
1
0
25
分享
相关文章
微服务——SpringBoot使用归纳——Spring Boot返回Json数据及数据封装——封装统一返回的数据结构
本文介绍了在Spring Boot中封装统一返回的数据结构的方法。通过定义一个泛型类`JsonResult&lt;T&gt;`,包含数据、状态码和提示信息三个属性,满足不同场景下的JSON返回需求。例如,无数据返回时可设置默认状态码&quot;0&quot;和消息&quot;操作成功!&quot;,有数据返回时也可自定义状态码和消息。同时,文章展示了如何在Controller中使用该结构,通过具体示例(如用户信息、列表和Map)说明其灵活性与便捷性。最后总结了Spring Boot中JSON数据返回的配置与实际项目中的应用技巧。
214 0
|
4月前
|
微服务——SpringBoot使用归纳——Spring Boot返回Json数据及数据封装——使用 fastJson 处理 null
本文介绍如何使用 fastJson 处理 null 值。与 Jackson 不同,fastJson 需要通过继承 `WebMvcConfigurationSupport` 类并覆盖 `configureMessageConverters` 方法来配置 null 值的处理方式。例如,可将 String 类型的 null 转为 &quot;&quot;,Number 类型的 null 转为 0,避免循环引用等。代码示例展示了具体实现步骤,包括引入相关依赖、设置序列化特性及解决中文乱码问题。
107 0
|
4月前
|
微服务——SpringBoot使用归纳——Spring Boot返回Json数据及数据封装——Spring Boot 默认对Json的处理
本文介绍了在Spring Boot中返回Json数据的方法及数据封装技巧。通过使用`@RestController`注解,可以轻松实现接口返回Json格式的数据,默认使用的Json解析框架是Jackson。文章详细讲解了如何处理不同数据类型(如类对象、List、Map)的Json转换,并提供了自定义配置以应对null值问题。此外,还对比了Jackson与阿里巴巴FastJson的特点,以及如何在项目中引入和配置FastJson,解决null值转换和中文乱码等问题。
314 0
SpringBoot整合Flowable【06】- 查询历史数据
本文介绍了Flowable工作流引擎中历史数据的查询与管理。首先回顾了流程变量的应用场景及其局限性,引出表单在灵活定制流程中的重要性。接着详细讲解了如何通过Flowable的历史服务API查询用户的历史绩效数据,包括启动流程、执行任务和查询历史记录的具体步骤,并展示了如何将查询结果封装为更易理解的对象返回。最后总结了Flowable提供的丰富API及其灵活性,为后续学习驳回功能做了铺垫。
292 0
SpringBoot整合Flowable【06】- 查询历史数据
Java||Springboot读取本地目录的文件和文件结构,读取服务器文档目录数据供前端渲染的API实现
博客不应该只有代码和解决方案,重点应该在于给出解决方案的同时分享思维模式,只有思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~
Java||Springboot读取本地目录的文件和文件结构,读取服务器文档目录数据供前端渲染的API实现
SpringBoot + 通义千问 + 自定义React组件:支持EventStream数据解析的技术实践
【10月更文挑战第7天】在现代Web开发中,集成多种技术栈以实现复杂的功能需求已成为常态。本文将详细介绍如何使用SpringBoot作为后端框架,结合阿里巴巴的通义千问(一个强大的自然语言处理服务),并通过自定义React组件来支持服务器发送事件(SSE, Server-Sent Events)的EventStream数据解析。这一组合不仅能够实现高效的实时通信,还能利用AI技术提升用户体验。
655 2
SpringBoot 通过集成 Flink CDC 来实时追踪 MySql 数据变动
通过详细的步骤和示例代码,您可以在 SpringBoot 项目中成功集成 Flink CDC,并实时追踪 MySQL 数据库的变动。
1073 43
SpringBoot整合Flowable【05】- 使用流程变量传递业务数据
本文介绍了如何使用Flowable的流程变量来管理绩效流程中的自定义数据。首先回顾了之前的简单绩效流程,指出现有流程缺乏分数输入和保存步骤。接着详细解释了流程变量的定义、分类(运行时变量和历史变量)及类型。通过具体代码示例展示了如何在绩效流程中插入全局和局部流程变量,实现各节点打分并维护分数的功能。最后总结了流程变量的使用场景及其在实际业务中的灵活性,并承诺将持续更新Flowable系列文章,帮助读者更好地理解和应用Flowable。 简要来说,本文通过实例讲解了如何利用Flowable的流程变量功能优化绩效评估流程,确保每个环节都能记录和更新分数,同时提供了全局和局部变量的对比和使用方法。
415 0
SpringBoot整合Flowable【05】- 使用流程变量传递业务数据
SpringBoot使用mysql查询昨天、今天、过去一周、过去半年、过去一年数据
SpringBoot使用mysql查询昨天、今天、过去一周、过去半年、过去一年数据
218 9
|
9月前
|
mybatis使用三:springboot整合mybatis,使用PageHelper 进行分页操作,并整合swagger2。使用正规的开发模式:定义统一的数据返回格式和请求模块
这篇文章介绍了如何在Spring Boot项目中整合MyBatis和PageHelper进行分页操作,并且集成Swagger2来生成API文档,同时定义了统一的数据返回格式和请求模块。
211 1
mybatis使用三:springboot整合mybatis,使用PageHelper 进行分页操作,并整合swagger2。使用正规的开发模式:定义统一的数据返回格式和请求模块
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等