C#.NET 大型通用信息化系统集成快速开发平台 4.1 版本 - .NET商业化成品成熟各种数据权限的需求对应例子代码
2014-10-10 12:44 通用C#系统架构 阅读(2856) 评论(2) 编辑 收藏 举报还是我上次提出的那个问题
问题:
假设一个订单表,
1.角色A可以看自己的
2.角色B可以看工作组的
3.角色C可以看金额是1000元以下的(自定义条件是否可行?如果可以,请详细说明)
4.角色D可以看整个部门的
5.角色E可以看整个分公司的
6.角色F可以看各分子公司的
参考代码如下:代码量会非常小,而且根本不需要写6个函数的,其实就按钮3的方法其实可以同时满足6个需求的
using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Linq; using System.Text; using System.Windows.Forms; namespace DotNet.Example { using DotNet.WinForm; using DotNet.Utilities; using DotNet.Business; public partial class FrmByPermission : BaseForm { public FrmByPermission() { InitializeComponent(); } /* 问题:假设一个订单表,角色A可以看自己的,角色B可以看工作组的, 角色C可以看金额是1000元以下的(自定义条件是否可行?如果可以,请详细说明),角色D可以看整个部门的, 角色E可以看整个分公司的,角色F可以看各分子公司的,这该怎么做,还有怎样配置,谢谢。 */ private void btnGetUser1_Click(object sender, EventArgs e) { // 1: 定义几个操作权限、谁有什么操作来控制,数据权限。 // 2: 系统里总有一个地方需要硬编码,例如 查看全公司的人员档案的权限。 // 3: 权限编码,用中文还是用英文,其实是一样的,主要看目标人群是什么, “AllCompany”权限 == “全公司”权限 // 4: 在上面的权限限制的基础上,继续+了条件表达式的2次限制权限 // 保存用户的设置 BaseParameterManager parameterManager = new BaseParameterManager(); parameterManager.SetParameter("User", this.UserInfo.Id, "Score", this.txtScore.Text); // 读取用户的积分条件设置 string score = parameterManager.GetParameter("User", this.UserInfo.Id, "Score"); string whereConditional = BaseUserEntity.FieldScore + "<= " + score; BaseUserManager userManager = new BaseUserManager(this.UserInfo); this.drgUser.DataSource = userManager.GetUserByPermission(whereConditional); } private void btnGetUser2_Click(object sender, EventArgs e) { // 1: 在某个角色,就当是有相应的权限。 // 2: 有个角色就叫“全公司”数据查看的角色,例如“AllCompany” // 3: 角色名称,用英文、用中文是一样的。 // 4: 在上面的权限限制的基础上,继续+了条件表达式的2次限制权限 // 保存用户的设置 BaseParameterManager parameterManager = new BaseParameterManager(); parameterManager.SetParameter("User", this.UserInfo.Id, "Score", this.txtScore.Text); // 读取用户的积分条件设置 string score = parameterManager.GetParameter("User", this.UserInfo.Id, "Score"); string whereConditional = BaseUserEntity.FieldScore + "<= " + score; BaseUserManager userManager = new BaseUserManager(this.UserInfo); this.drgUser.DataSource = userManager.GetUserByRolePermission(whereConditional); } private void btnGetUser21_Click(object sender, EventArgs e) { // 角色A可以看自己的 BaseUserManager userManager = new BaseUserManager(this.UserInfo); this.drgUser.DataSource = userManager.GetUserByRolePermission(); } private void btnGetUser22_Click(object sender, EventArgs e) { // 角色B可以看工作组的 BaseUserManager userManager = new BaseUserManager(this.UserInfo); this.drgUser.DataSource = userManager.GetUserByRolePermission(); } private void btnGetUser23_Click(object sender, EventArgs e) { // 角色C可以看金额是1000元以下的(自定义条件是否可行?如果可以,请详细说明) // 保存用户的设置 BaseParameterManager parameterManager = new BaseParameterManager(); parameterManager.SetParameter("User", this.UserInfo.Id, "Score", this.txtScore.Text); // 读取用户的积分条件设置 string score = parameterManager.GetParameter("User", this.UserInfo.Id, "Score"); string whereConditional = BaseUserEntity.FieldScore + "<= " + score; BaseUserManager userManager = new BaseUserManager(this.UserInfo); this.drgUser.DataSource = userManager.GetUserByRolePermission(whereConditional); } private void btnGetUser24_Click(object sender, EventArgs e) { // 角色D可以看整个部门 BaseUserManager userManager = new BaseUserManager(this.UserInfo); this.drgUser.DataSource = userManager.GetUserByRolePermission(); } private void btnGetUser25_Click(object sender, EventArgs e) { // 角色E可以看整个分公司 BaseUserManager userManager = new BaseUserManager(this.UserInfo); this.drgUser.DataSource = userManager.GetUserByRolePermission(); } private void btnGetUser26_Click(object sender, EventArgs e) { // 角色F可以看各分子公司 BaseUserManager userManager = new BaseUserManager(this.UserInfo); this.drgUser.DataSource = userManager.GetUserByRolePermission(); } } }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 单线程的Redis速度为什么快?
· 展开说说关于C#中ORM框架的用法!
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· Pantheons:用 TypeScript 打造主流大模型对话的一站式集成库
· SQL Server 2025 AI相关能力初探
2010-10-10 为什么只要2k月薪也不录用这些应聘者?