超管用户问题

超管用户问题

一、背景
后台系统中需要权限管控模块交互,在用户上线时,如何识别用户身份以及通过权限校验在系统中进行交互操作,比如创建权限、角色、分配角色成员等等。

二、需求
系统上线之后,有超管用户能去操作系统,无需鉴权才能交互。
三、方案
1、硬编码超管用户
直接在代码里定义超管用户工号,判断登录账号工号,忽略鉴权直接进行交互
优点:简单粗暴,直接在代码里管理超管用户列表
缺陷: 用户离职或者调岗等场景会导致超管用户列表失效,无有效超管用户
2、无需鉴权链接
通过特殊路径登录访问时,忽略鉴权,可以直接进行交互
优点:无需硬编码管理超管用户列表,通过链接参数跳过鉴权
缺陷:需要通过特殊路径访问才可以无需鉴权,不存在超管用户,不可配置路径参数的场景下无法解决超管问题,由于不存在超管用户,导致链接失效后,无超管用户。同时存在
3、本地数据直接赋予超管身份
修改本地浏览器缓存数据,修改sessionStorage 或localStorage的值来直接赋予用户权限
优点: 无需硬编码管理用户列表,直接在前端数据中赋予权限
缺陷:清除本地数据之后用户会丢失超管身份,权限数据需要能在本地读取并修改
以上三个方案都是只能在前端做权限鉴权,后端没有做权限鉴权的场景下生效
4、后端提供超级管理员用户识别api
超管用户维护在后端,不在前端明码出现,需要维护超管用户列表
5、直接修改数据库数据
修改数据库直接赋予用户超管身份
同步导入预发布环境的数据,配置对应角色和身份

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值