菜单权限功能设计

一. 方案1

菜单数据

菜单数据如果非常简单,固定不变,我们可以直接用json文件来维护。每个菜单有个id标识唯一性,菜单有父子关系,最多三级。有些菜单还支持配置按钮权限。

XML 复制代码
{
  "menu": [
    {
      "parent_id": "",
      "id": "data_analysis",
      "name": "数据分析",
      "button_list": null,
      "children": [
        {
          "parent_id": "data_analysis",
          "id": "data_analysis_1",
          "name": "商家信息",
          "button_list": [
            {
              "button_name": "搜索",
              "button_id": "data_analysis_1_search"
            }
          ],
          "children": []
        }
      ]
    }
  ]
}

路由权限数据

菜单和其相关的按钮都可以绑定多个路由,一个角色配置了菜单和按钮的权限,则其就具备对应的路由权限。路由权限数据也可用json来维护,内容就是简单的kv,key是菜单id或者按钮id,value是一个数组存一批路由。

复制代码
{
  "data_analysis_1": [
    "/admin/data/list"
  ],
  "data_analysis_1_search": [
    "/admin/data/detail"
  ]
}

角色表和角色权限表

按照角色分配菜单权限,所以分配的对象是菜单。我们需要维护一个角色表。比如 admin_role, 核心字段就是角色的唯一标识,比如 role_id。

给用户分配的菜单,需要一个角色菜单表记录它们的关联。有些菜单中还有按钮等操作单元,我们统一可以记录角色和这些按钮操作的关系。所以创建个表,比如 admin_role_access

表中字段

  • menu_id_data:
    • 存一个角色有哪些菜单配置,用json维护一个数组,元素就是每个菜单的id。
    • 比如如果没用权限,那么 menu_id_data的值为 {"menu_data": []}
    • 如果给某个角色勾选了一个菜单权限,这个菜单id就会存起来,比如{"menu_data": ["data_analysis", "data_analysis_1"]}
  • button_id_data:
    • 存一个角色有哪些菜单的button权限,也是用json维护的数组,元素就是每个button的id。
    • 比如如果没用权限,那么 button_id_data的值为{"button_data": []}
    • 如果给某个角色勾选了某个菜单下的按钮权限,这个按钮id就会存起来,比如{"button_data": ["data_analysis_1_search"]}
相关推荐
爱学习的阿磊3 小时前
使用Fabric自动化你的部署流程
jvm·数据库·python
枷锁—sha3 小时前
【SRC】SQL注入快速判定与应对策略(一)
网络·数据库·sql·安全·网络安全·系统安全
惜分飞3 小时前
ORA-600 kcratr_nab_less_than_odr和ORA-600 4193故障处理--惜分飞
数据库·oracle
chian-ocean3 小时前
CANN 生态进阶:利用 `profiling-tools` 优化模型性能
数据库·mysql
m0_550024633 小时前
持续集成/持续部署(CI/CD) for Python
jvm·数据库·python
AC赳赳老秦3 小时前
代码生成超越 GPT-4:DeepSeek-V4 编程任务实战与 2026 开发者效率提升指南
数据库·数据仓库·人工智能·科技·rabbitmq·memcache·deepseek
啦啦啦_99994 小时前
Redis-2-queryFormat()方法
数据库·redis·缓存
玄同7654 小时前
SQLite + LLM:大模型应用落地的轻量级数据存储方案
jvm·数据库·人工智能·python·语言模型·sqlite·知识图谱
吾日三省吾码4 小时前
别只会“加索引”了!这 3 个 PostgreSQL 反常识优化,能把性能和成本一起打下来
数据库·postgresql
chian-ocean4 小时前
百万级图文检索实战:`ops-transformer` + 向量数据库构建语义搜索引擎
数据库·搜索引擎·transformer