news 2026/5/2 14:13:19

仿照若依框架进行数据权限控制

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
仿照若依框架进行数据权限控制

用的方案其实就是“若依”那套思路,不过自己做了点裁剪,核心就四步——注解标识、AOP 拦截、SQL 拼接、MyBatis 消费。下面按执行顺序捋一遍:

  1. 打标记
    在需要控制权限的 Mapper 方法上贴一个自定义注解@DataScope,里面两个值:

    @DataScope(deptAlias="d",userAlias="u")List<Xxx>selectList(Xxxparam);

    这样一眼就能看出“这个方法要走数据权限”。

  2. AOP 切面
    专门写了一个DataScopeAspect,进入方法之前先跑:

    • 清理 ThreadLocal,防止线程复用串数据;
    • 从 Spring Security 上下文里拿当前登录用户,包括他的角色、部门 ID、用户 ID;
    • 如果是超级管理员,直接放行;否则根据角色提前配置好的“数据范围”枚举拼 SQL 片段,比如“本部门及以下”就用find_in_set(ancestors),“仅本人”就create_by = #{userId}
  3. 把条件塞进实体
    所有实体都继承BaseEntity,里面有个临时字段dataScope。切面通过反射把第 2 步拼好的 SQL 片段塞进去,再往下传。

  4. MyBatis 消费
    XML 里统一加一句:

    <iftest="dataScope != null and dataScope !=''">${dataScope}</if>

    真正发到数据库的 SQL 就带上了权限过滤条件,返回的数据自然就是当前用户能看的那部分。


亮点补充

  • 对业务代码零侵入,只在 Mapper 层加注解,Service 层无感知。
  • SQL 片段统一维护,换需求只改枚举,不动业务。
  • 线程级 ThreadLocal + 用完即清理,没有内存泄漏风险。
  • 后面做 SaaS 多租户时,把“租户 ID”字段也加进来,同一套切面直接复用。

一句话总结
“注解一贴,切面自动把‘部门/个人’范围拼成 SQL,MyBatis 尾巴一接,数据权限就生效,全程业务代码无感,改需求只改配置。”

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/29 20:23:23

LobeChat能否支持多轮谈判?复杂决策模拟

LobeChat 能否支持多轮谈判与复杂决策模拟&#xff1f; 在企业智能对话系统日益复杂的今天&#xff0c;用户早已不满足于“问一句答一句”的机械交互。他们期待 AI 能够真正参与薪资谈判、合同协商、商业推演这类需要长期记忆、角色代入和动态决策的高阶任务。这背后考验的不仅…

作者头像 李华
网站建设 2026/5/1 10:54:49

UnityRenderStreaming内网转发到公网

1、coturn 前文已编译好了coturn https://xue-fei.blog.csdn.net/article/details/155945401 配置文件 turnserver.conf # 监听地址和端口 listening-port3478 tls-listening-port5349 listening-ip0.0.0.0# 你的公网 IP&#xff08;必须&#xff01;用于 NAT 穿透&#xff0…

作者头像 李华
网站建设 2026/5/1 8:01:57

复刻DeepSeek与GPT!AI智能对话Web高保真原型设计全解析

引言到2026年&#xff0c;DeepSeek、ChatGPT这类产品的界面形态&#xff0c;仍然是许多AI智能对话类应用的参考起点。实际做下来会发现&#xff0c;不管是产品经理还是UI设计师都会遇到一个的难点&#xff0c;就是怎么既能保证沉浸式对话的体验&#xff0c;同时还可以承载复杂的…

作者头像 李华
网站建设 2026/4/19 4:43:08

Stable Diffusion 3.5本地部署指南

Stable Diffusion 3.5本地部署指南&#xff1a;FP8量化模型高效部署实战 在AI图像生成技术飞速演进的今天&#xff0c;一个关键瓶颈始终困扰着普通用户和开发者——如何在有限的硬件资源下&#xff0c;稳定运行越来越庞大的文生图模型&#xff1f;直到Stability AI推出 Stable…

作者头像 李华