分享好友 最新动态首页 最新动态分类 切换频道
从产品经理视角谈用户权限
2025-01-07 17:58

只要在系统中存在多个用户,必然会涉及到用户权限的处理问题。这篇文章,作者总结了用户权限的相关问题,包括定义、搭建和自己的思考,供各位参考。

图片

前几天与一位产品朋友闲聊的时候有聊到某项目的用户权限应该如何设计的话题,当时在我脑海中闪过了许多解决方案,但是我却不知道如何有逻辑性的进行表达,于是我意识到是该总结输出的时候了……

用户权限是所有应用系统最底层的逻辑,只要系统中存在多用户,那么就必然会涉及到用户权限的概念。用户权限是集模块权限、功能权限、数据权限为一体的统称。

下面以一个ERP系统的部分场景为例来解释说明什么是用户权限,例如在一个ERP应用系统中包含了销售、采购、财务等功能。

模块权限也叫菜单权限或应用权限,即决定一个用户在应用系统中可以使用哪些模块菜单。

在示例中,公司的销售人员就只能查看与销售相关的业务模块,而不应该能看到财务相关的功能模块。因此我们可以通过配置模块权限来实现不同用户的模块隔离。

功能权限也叫按钮权限,即决定一个用户在一个业务模块中可以使用哪些功能按钮。

在示例中,普通销售人员在销售订单管理模块中只能有新增订单、编辑订单、删除订单、申请优惠等功能,而销售总监除了有这些功能外,还会多一些审批优惠、查看销售报表等功能。因此我们可以通过配置功能权限来实现不同用户在同一个业务模块中的功能按钮不同。

数据权限可以细拆为查看数据权限和管理数据权限。

查看数据权限,即决定一个用户在模块中可以查看哪些数据记录。在示例中,普通销售人员在销售订单管理模块中只能查看自己创建的销售订单,而销售总监则可以查看整个销售部门的销售订单记录。因此我们可以通过配置查看数据权限来实现不同用户在同一个业务模块中的数据隔离。

管理数据权限,即决定一个用户在可以查看的数据基础之上允许对哪些数据进行操作。在示例中,所有采购人员在采购订单管理模块中都可以查看所有的采购订单,但是采购人员A只能对自己创建的采购订单进行编辑、删除等操作,不能对其他采购人员的订单进行操作。因此我们可以通过配置管理数据权限来实现不同用户在同一个业务模块中查看同样数据的情况下,可操作的数据不同。

用户权限的核心就是在一个应用系统中控制哪些用户能查看哪些模块的哪些数据以及可以对哪些数据做哪些操作。

这句话看上去可能比较绕,但带入实际业务流程就会很好理解了。

在实际业务场景中,每个用户都是有自己的部门和岗位,所以设置用户权限的第一个目的就是职责分明。不同部门不同岗位的用户在应用系统中都需要有各自对应匹配的功能流程,这不仅可以简化用户操作和提升用户体验,还避免因功能模块繁杂造成用户的困扰与混淆。

其次是为了数据安全保障。各类数据都有着不同的敏感性,例如公司的所有客户信息、供应商信息、财务信息等一旦被泄露均可能产生严重后果。通过设置用户权限就能将不同的数据信息分别授权给部分指定人员,这样就有效防止了数据被泄露的风险。

另外还可以用于做个性化体验等操作,例如在SaaS版系统中可以利用后台运营系统的用户权限给部分用户开放灰度测试功能或给指定用户开放指定功能,以便于满足不同用户的多样化业务需求。

搭建一个好的用户权限体系就像修房子搭建一个稳定的地基一样。因此在设计用户权限体系时需要尽可能设置的通用一些,这样才有利于后续的系统建设以及响应需求变更。

我把之前负责和参与过的所有产品和项目综合整理出了一个通用的用户权限配置模型,如下图所示。

图片

✧通常情况下,一个功能页面就是一个菜单配置项,然后可以根据实际的业务场景来决定是否配置二级或三级菜单等。

✧我创建的:仅能查看自己创建的数据。

✧我参与的:仅能查看与自己有关联的数据,如自己创建的、业务数据审批人或抄送人是自己的。

✧本级部门创建的:仅能查看自己所在部门本级所有人员创建的数据。

✧本级及上级部门创建的:仅能查看自己所在部门本级及上级所有人员创建的数据。

✧本级及下级部门创建的:仅能查看自己所在部门本级及下级所有人员创建的数据。

✧全部:可以查看该模块的所有数据。

✧我创建的:仅可以操作自己创建的数据。

✧我可见的:仅可以操作与自己有关联的数据,如自己创建的、业务数据审批人或抄送人是自己的。

✧我可见的:所有能查看的数据都可以操作。

✧按照模块中的功能操作按钮列举,越详细越好。

有些多应用型的系统则可以在模块菜单的前面再套一层应用权限配置,如下图。

图片

在实际项目开发过程中,用户权限也不一定全部都需要做成可配置项,可根据项目的实际情况将上述搭建规则的部分权限直接在代码里写死控制,只不过这么干的后果就是当后期有关于权限的需求变动时,需要由程序员修改代码并发版之后才能生效。

在实际业务中,用户角色与用户通常是多对多的情况,即一个角色下存在多个用户,而一个用户也可能拥有多个角色。所以为了方便在系统中管理,我们可以设置“角色组”的概念。即将多个用户角色打包为一个角色分组,并将这个分组赋予用户,这样一个用户就同时拥有了这个角色组下的多个角色的权限。但是当一个用户同时拥有多个角色权限时,又会出现另外一个问题是这位用户在系统中最终的权限是什么呢?这个问题通常的解决方案有2种,一种是多个角色的权限取并集;另一种是让用户手动选择自己的当前角色。具体采用哪种解决方案可根据实际业务场景来决定。

关于数据权限还有一个常见的问题是当一位用户从A部门转移到B部门之后,那这位用户之前在A部门产生的数据是保留在A部门还是跟随用户转移到B部门呢?这个问题需要在做权限设计时提前考虑到,但具体如何处理也是需要根据实际业务场景来决定。

最新文章
虚拟世界游戏xda智能手机网「虚拟世界游戏」
虚拟世界游戏是一款卡通积木风格的自由创造类模拟建设开放世界游戏,在游戏中玩家可以选择多种多样的风格材质建设出不同的建筑和世界,享受独属于自己的奇妙冒险。注:安装包名为Roblox,与本页介绍为同一游戏。 完全免费的 3D 聊天和互发
苹果iPhone 16大卖,夺回全球智能手机销量第一苹果手机市场「苹果iPhone 16大卖,夺回全球智能手机销量第一」
最近,全球智能手机市场的最新动态引发了行业内外的广泛关注。根据Counterpoint Research发布的一份报告,2024年第3季度全球智能手机销量同比增长2%,这是自2018年第3季度以来首次出现的同比正增长,标志着全球智能手机市场正在逐渐复苏。
猎豹免费无线wifi怎么安装 详细步骤指南:如何安装和使用猎豹免费无线WiFi猎豹免费wifi手机版「猎豹免费无线wifi怎么安装 详细步骤指南:如何安装和使用猎豹免费无线WiFi」
在现代社会,无线网络已经成为我们日常生活和工作中不可或缺的一部分,无论是在家中,还是在公共场所,我们都需要无线网络来浏览网页,观看视频,进行在线交流等,有时候我们可能会遇到网络不稳定,速度慢等问题,我们就需要使用一些工具来
手机安全模式怎么办?详细步骤教你轻松解除!vivo手机安全模式怎么解除「手机安全模式怎么办?详细步骤教你轻松解除!」
在我们日常生活中,手机早已成为不可或缺的智能设备,帮助我们连接世界。然而,有时候,我们会遇到手机突然进入安全模式的尴尬局面。安全模式作为手机一项重要的自我保护机制,会关闭大部分非核心功能,以确保手机在面临软件冲突或潜在病毒
超帅!一键远程开机,简单几步让你手机远程开电脑手机静态ip「超帅!一键远程开机,简单几步让你手机远程开电脑」
远程软件大家肯定耳熟能详,通常用来主动远程协助他人,远程控制的功能丰富又强大,不知道大家在个人远程使用场景中,有没有碰到过需要远程开机的情况,比如回家后突然需要办公室电脑中的文件,或者需要远程运行家中电脑上某个程序,这种情
西宁陈某心生歹念,竟然……手机货到付款「西宁陈某心生歹念,竟然……」
蓝字关注“972青海交通音乐广播近期,西宁一男子将自己在网上买的手机盗走,在二手市场进行变卖,最终被公安机关抓获。这是怎么回事呢?一起来了解一下……近日,西宁市公安局城中公安分局南川西路派出所接到一快递小哥报警,称其配送的快
手机怎么改自己家的wifi密码手机怎么改wifi密码「手机怎么改自己家的wifi密码」
随着智能家居的普及,WiFi已经成为我们日常生活中不可或缺的一部分。然而,出于安全考虑,我们时常需要更改WiFi密码。那么,如何在手机上轻松修改自己家的WiFi密码呢?下面将分点为您详细解答。**一、连接WiFi网络**首先,确保您的手机已经
拳皇97屠蛇版无限气拳皇97手机版下载「拳皇97屠蛇版无限气」
拳皇97屠蛇版无限气是一款竞技格斗游戏,游戏描述无限气采用经典的2D画面,玩家可以选择多个游戏模式,包括单人、双人和挑战模式。游戏中有多个可玩角色,每个角色都有独特的招式和技能,玩家可以通过不断练习,熟练掌握各种技巧,最终成为
iphone13pro怎么关机重启手机怎么关机重启「iphone13pro怎么关机重启」
iphone13pro是非常不错的旗舰机型,这款手机自从正式上市以来就很火爆,一直以来都保持着很高的销量,虽然已经发布一段时间了,但是这款手机依然还有不少用户们正在使用,入手的用户们难免会遇到各种问题,比如iphone13pro怎么关机重启?接
相关文章
推荐文章
发表评论
0评