权限管理、用户权限系统、开源用户权限系统、信息化建设标准基础数据管理平台
代码改变世界

通用权限管理系统组件回答用户的常用问题:操作权限、用户角色、数据权限的解决方法

  通用C#系统架构  阅读(5112)  评论(2编辑  收藏  举报

1. 页面,通过权限控制某个页面是否能显示
2. 按钮,通过权限控制某个页面上的按钮是否能显示
3. 方法,通过权限控制某个方法(Service方法或者Server方法)是否能显示
4. 数据行,通过权限控制某个用户只能看到某几行数据

 

回答1:这个是属于菜单权限,所有的菜单都可以进行配置维护,然后通过 bs 中的 Utilities.GetUserPermissionList(userInfo); 函数可以获取当前用户所有能访问的菜单List。

回答2:每个按钮都可以编上一个编号,然后在页面上调用 this.IsAuthorized("Project.Edit") 这个函数获取到当前用户是否有这个操作权限。按后按自己的意愿无效或者不显示处理。

回答3:是否允许调用某个方法,可以参考问题2,每个服务都编上一个号码,调用更底层一点儿封装的函数就可以了,转到定义就可以找到了,permissionService.IsAuthorizedByUser。

回答4:this.UserInfo.CompanyId, this.UserInfo.SubCompanyId, this.UserInfo.DepartmentId, this.UserInfo.WorkgroupId 类似函数可以获得当前用户的所在公司等信息,

然后结合当前用户是否在哪个角色 BaseUserManager.IsInRoleByCode的函数

在结合业务数据库里的公司部门字段,拼接where sql语句就可以了,几乎常用的行权限问题全搞定了,例如下图

 

编辑推荐:
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
阅读排行:
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· Docker 太简单,K8s 太复杂?w7panel 让容器管理更轻松!
历史上的今天:
2008-11-19 通用权限实现的核心设计思想


C# ASP.NET 通用权限设计、通用权限管理、通用权限组件、单点登录、集中式权限管理、统一授权体系、分级管理分级授权


微信扫一扫加好友



点击右上角即可分享
微信分享提示