当前位置:首页 > 科技  > 软件

权限管理——多系统下的数据权限通用控制

来源: 责编: 时间:2023-11-02 09:08:18 428观看
导读大家好:常见的,在项目实际开发中我们不光要控制一个用户能访问哪些资源,还需要控制用户只能访问资源中的某部分数据。这就是所谓的数据权限。典型的如列表数据权限,主要通过数据权限控制行数据,让不同的人有不同的查看数据

大家好:

常见的,在项目实际开发中我们不光要控制一个用户能访问哪些资源,还需要控制用户只能访问资源中的某部分数据。这就是所谓的数据权限。典型的如列表数据权限,主要通过数据权限控制行数据,让不同的人有不同的查看数据规则。XFT28资讯网——每日最新资讯28at.com

行业背景

在互联网系统中,权限一般分为功能权限和数据权限,功能权限比较常见,因为通用性和复用性,业内有很多的通用框架和设计。但对应数据权限来说,由于数据权限强依赖客户组织架构和具体业务的关系,往往实现起来会比较复杂,很少有一个设计架构能完全覆盖住,所以大部分的系统都一致性的遵循此策略:如非必要的尽量不使用数据权限,必须要的则单独控制。XFT28资讯网——每日最新资讯28at.com

目前常见数据权限方案基本为硬编码,具体分为如下两种:一是拆分功能页面,即根据不同数据权限用户,通过复制拷贝的方式,增加多个类似的菜单,再通过功能权限配置来给不同用户设置不同的菜单,从而实现数据权限的控制;二是在功能对应的后端接口里做判断,对不同数据权限的用户,过滤不同的数据列表透出给用户。硬编码的方式显而易见的优点是技术难度低,实现简单。XFT28资讯网——每日最新资讯28at.com

但以上硬编码的方式,无论选择用哪一种,都无法解决系统灵活性的问题,每当系统有老的需求要变更或者新的需求要新增,对应的开发人员就不得不去调整编码,修改菜单和页面,由此可见,硬编码对开发的成本和运维的成本都比较高。与此同时,行业内常见的通用数据权限控制,大都是给单一业务使用,和业务耦合度较高,可能在当前业务客户端是通用可扩展的,但是在另一个业务客户端就无法做到无缝接入了。XFT28资讯网——每日最新资讯28at.com

因此,如何提高数据权限设置的灵活性,降低耦合性,是本领域技术人员需要解决的问题。XFT28资讯网——每日最新资讯28at.com

建设价值

首先来说一下,为什么我们要做这样一个多系统的数据权限控制装置?XFT28资讯网——每日最新资讯28at.com

大背景是我司当前有多个业务系统需要通过数据权限控制业务数据,它们的用户体系或相同或不同,控制维度各有定制。XFT28资讯网——每日最新资讯28at.com

于是产生诸如以下需求:XFT28资讯网——每日最新资讯28at.com

  • 权限可配置化
  • 支持业务快速接入
  • 模型统一

为了支持以上需求,于是理所当然的出现了如下一套多系统的通用数据权限控制系统。XFT28资讯网——每日最新资讯28at.com

系统介绍

本系统底层使用统一的一套模型,支持权限配置化,业务方可自定义权限维度,用户体系解耦,满足不同系统快速接入数据权限的业务场景。XFT28资讯网——每日最新资讯28at.com

数据权限

RBAC是经典的功能权限模型,它是 Role-BasedAccess Control 的英文缩写,意思是基于角色的访问控制。XFT28资讯网——每日最新资讯28at.com

运营事先会在系统中定义出各种不同的角色,不同的角色拥有不同的权限,一个角色实际上就是一组权限的集合。而系统的所有用户都会被分配到不同的角色中,一个用户可能拥有多个角色。使用这种模型可以极大地简化权限的管理。XFT28资讯网——每日最新资讯28at.com

但是,在该模型下,系统只会验证用户甲是否属于角色A,而不会判断用户甲是否能访问只属于用户乙的数据 Data。这种问题我们称之为“水平权限管理问题”。XFT28资讯网——每日最新资讯28at.com

所以,为了解决这个问题,我们基于 RBAC 模型下,又扩展了功能和维度的概念,使系统能基于角色控制用户的数据权限。如下:XFT28资讯网——每日最新资讯28at.com

图片图片XFT28资讯网——每日最新资讯28at.com

同时,为了做到多系统通用,我们又对系统、功能、权限做了如下抽象:XFT28资讯网——每日最新资讯28at.com

图片图片XFT28资讯网——每日最新资讯28at.com

模型把每个系统抽象成由一个个业务组成,业务下分解成多个功能,功能对应多个维度:XFT28资讯网——每日最新资讯28at.com

  • 数据权限的颗粒度为到功能,一个功能可包含多个 Rest 接口。
  • 功能下分多个维度,所谓的数据权限实际就是控制每个维度,维度最终对应的是每个功能业务数据的筛选字段。
  • 最终当所有都配置完成后,每个角色对应每个功能下就挂着多个数据规则。当用户访问具体功能时,根据用户角色的数据规则,返回对应数据。
  • 当固定值不满足业务需求时,提供开放端口给业务方,业务方可实现对应维度的选择项端口,来达到自定义维度对应值的目的。

数据规则

根据以上描述,显而易见的,要实现数据权限,最重要的是需要抽象出数据规则。XFT28资讯网——每日最新资讯28at.com

比如我们营销系统的订单列表,需要从下面几个维度来控制数据访问权限。XFT28资讯网——每日最新资讯28at.com

销售人员只能看自己的数据;XFT28资讯网——每日最新资讯28at.com

a 部门的人只能看自己部门的数据;XFT28资讯网——每日最新资讯28at.com

a 部门的上级部门 A 的人能看自己部门的数据和下级 b 部门的人;XFT28资讯网——每日最新资讯28at.com

上面的这些维度就是数据规则。XFT28资讯网——每日最新资讯28at.com

这样数据规则的几个重点要素我们也明晰了,就是规则字段,规则表达式,规则值,上面三个场景对应的规则分别如下:XFT28资讯网——每日最新资讯28at.com

规则字段:创建人,规则表达式:= ,规则值:当前登录人XFT28资讯网——每日最新资讯28at.com

规则字段:所属部门,规则表达式:= ,规则值:aXFT28资讯网——每日最新资讯28at.com

规则字段:所属部门,规则表达式:in ,规则值:A,aXFT28资讯网——每日最新资讯28at.com

即数据规则由【维度+条件表达式+维度对应值】组成,业务数据的数据权限就是由多个数据规则组成的范围控制。具体模型如下:XFT28资讯网——每日最新资讯28at.com

图片图片XFT28资讯网——每日最新资讯28at.com

接入流程

那么,本套多系统权限控制系统,到底该如何接入呢?大致流程如下:XFT28资讯网——每日最新资讯28at.com

图片图片XFT28资讯网——每日最新资讯28at.com

按照此通用方案,数据控制整体接入过程如下:XFT28资讯网——每日最新资讯28at.com

1.业务确定需要数据权限接入的功能。XFT28资讯网——每日最新资讯28at.com

2.产品、开发、业务确认功能的维度。XFT28资讯网——每日最新资讯28at.com

3.运营在开发的支持下在运营管理端配置数据权限,包括支持的维度、表达式、固定值等等。如需自定义维度对应值,实现对应端口。XFT28资讯网——每日最新资讯28at.com

4.各系统管理员登录各自的数据权限配置端,设置每个角色的数据规则。XFT28资讯网——每日最新资讯28at.com

5.客户访问系统的具体功能,根据客户的角色,获得数据规则,根据数据规则组装业务数据返回。XFT28资讯网——每日最新资讯28at.com

接入案例-订单列表

订单是很常见的系统功能,当前,需要对不同员工查看订单的数据范围做控制,根据员工所属的部门不同,查看对应部门的订单列表。XFT28资讯网——每日最新资讯28at.com

步骤一:确定系统、功能、维度XFT28资讯网——每日最新资讯28at.com

系统:xxx系统 功能:订单列表 维度:部门XFT28资讯网——每日最新资讯28at.com

步骤二:管理端配置数据权限XFT28资讯网——每日最新资讯28at.com

图片图片XFT28资讯网——每日最新资讯28at.com

步骤三:业务方接入 Sdk,实现自定义维度(部门)选择项配置端口XFT28资讯网——每日最新资讯28at.com

示意代码XFT28资讯网——每日最新资讯28at.com

/** * 获取维度选择项  */List<DimensionOption> getDimensionOptionList(List<String> dimensionCodes);

步骤四: 对应api查询数据接口接入 Sdk,完成数据过滤XFT28资讯网——每日最新资讯28at.com

步骤五: 系统管理员配置角色数据权限XFT28资讯网——每日最新资讯28at.com

只要完成以上5步,就实现了接入数据权限的功能。整个流程只有接入 Sdk 的成本,1天内即可完成,快速、高效,极大的降低了成本。同时公司内所有系统都拥有了一套完整统一的权限控制系统。XFT28资讯网——每日最新资讯28at.com

Sdk 如何进行数据权限控制

那么,底层究竟是如何实现数据权限控制的?XFT28资讯网——每日最新资讯28at.com

以下是一个请求的控制链路:XFT28资讯网——每日最新资讯28at.com

图片图片XFT28资讯网——每日最新资讯28at.com

权限 Sdk 是真正实现权限控制的核心组件。XFT28资讯网——每日最新资讯28at.com

图片图片XFT28资讯网——每日最新资讯28at.com

Sdk 中的基石是一个个对外开放的端口,其中最底层的是上下文端口。接入方需实现这个端口接口,根据当前缓存用户封装数据权限上下文。如有自定义维度,需实现自定义维度选择项端口,返回业务自定义的维度选择项。XFT28资讯网——每日最新资讯28at.com

数据权限生效实现过程如下:XFT28资讯网——每日最新资讯28at.com

1.请求 Path 被 Sdk 拦截,通过正则匹配配置的权限 Api,匹配到说明需要被控制。XFT28资讯网——每日最新资讯28at.com

2.在功能接口中,Sdk 根据上下文端口获取当前请求上下文,根据上下文获取对应用户所有角色的数据权限。XFT28资讯网——每日最新资讯28at.com

3.根据数据权限设置的配置,组装权限控制的条件。XFT28资讯网——每日最新资讯28at.com

4.业务方查询时加上权限控制条件,得到的数据,就是控制了数据权限后的数据。XFT28资讯网——每日最新资讯28at.com

ps:本sdk只针对java语言的后端XFT28资讯网——每日最新资讯28at.com

如果业务方使用的是 MyBatis 的 Xml 原生语句, Sdk 会把所有的数据权限组装成对应的 Sql 片段,自动对XML查询注入该 Sql 片段;如果使用的是 MyBatis-plus 的 QueryWrapper 方式,Sdk 会把所有的数据权限自动注入到生成的 QueryWrapper 条件中。XFT28资讯网——每日最新资讯28at.com

业务方也可以自主使用权限控制配置查询数据,关闭 Sdk 的自动注入。XFT28资讯网——每日最新资讯28at.com

问题
  • 当前只能直接对数据库存在的字段进行控制,如果是间接条件,无法控制数据权限
  • 自动注入当前只支持 MyBatis 的 Xml 原生语句和 MyBatis-plus 的 QueryWrapper 方式,其他如 Jpa 等不支持
思考

还有更多的类似问题,都是多系统数据权限控制需要解决的。虽然具体到每个小点,单从技术的角度来说,可能未必很难,但要支持更多系统,具备更好的通用化,还有很长的一段路可走。这是一个会随着业务的发展,需要持续改进的工作。XFT28资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-16497-0.html权限管理——多系统下的数据权限通用控制

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: Spring Boot如何优雅提高接口数据安全性

下一篇: 轻松掌握Java的设计模式,写出优雅的代码

标签:
  • 热门焦点
  • MIX Fold3包装盒泄露 新机本月登场

    小米的全新折叠屏旗舰MIX Fold3将于本月发布,近日该机的真机包装盒在网上泄露。从图上来看,新的MIX Fold3包装盒在外观设计方面延续了之前的方案,变化不大,这也是目前小米旗舰
  • 对标苹果的灵动岛 华为带来实况窗功能

    继苹果的灵动岛之后,华为也在今天正式推出了“实况窗”功能。据今天鸿蒙OS 4.0的现场演示显示,华为的实况窗可以更高效的展现出实时通知,比如锁屏上就能看到外卖、打车、银行
  • 7月安卓手机性能榜:红魔8S Pro再夺榜首

    7月份的手机市场风平浪静,除了红魔和努比亚带来了两款搭载骁龙8Gen2领先版处理器的新机之外,别的也想不到有什么新品了,这也正常,通常6月7月都是手机厂商修整的时间,进入8月份之
  • 5月iOS设备性能榜:M1 M2依旧是榜单前五

    和上个月一样,没有新品发布的iOS设备性能榜的上榜设备并没有什么更替,仅仅只有跑分变化而产生的排名变动,刚刚开始的苹果WWDC2023,推出的产品也依旧是新款Mac Pro、新款Mac Stu
  • 5月安卓手机好评榜:魅族20 Pro夺冠

    性能榜和性价比榜之后,我们来看最后的安卓手机好评榜,数据来源安兔兔评测,收集时间2023年5月1日至5月31日,仅限国内市场。第一名:魅族20 Pro好评率:97.50%不得不感慨魅族老品牌还
  • 容量越大越不坏?24万块硬盘故障率报告公布 这些产品零故障

    8月5日消息,云存储服务商Backblaze发布了最新的硬盘故障率报告,年故障率有所上升。Backblaze发布的硬盘季度统计数据,其中包括故障率等重要方面。这些结
  • 十个可以手动编写的 JavaScript 数组 API

    JavaScript 中有很多API,使用得当,会很方便,省力不少。 你知道它的原理吗? 今天这篇文章,我们将对它们进行一次小总结。现在开始吧。1.forEach()forEach()用于遍历数组接收一参
  • 信通院:小米、华为等11家应用商店基本完成APP签名及验签工作

    中国信通院表示,目前,小米、华为、OPPO、vivo、360手机助手、百度手机助手、应用宝、豌豆荚和努比亚等9家应用商店,以及抖音和快手2家新型应用分发平
  • 英特尔Xe-HP项目终止,将专注Xe-HPC/HPG系列显卡

    据10 月 31 日消息报道,英特尔高级副总裁兼加速计算系统和图形事业部总经理 表示,Xe-HP“ Arctic Sound” 系列服务器 GPU 已经应用于 oneAPI devcloud 云服
Top