走火入魔.NET权限组件-字段访问权限(数据表字段的访问权限)思想来解决数据列的权限控制需求

本文涉及的产品
访问控制,不限时长
简介:

答应了客户写一个控制数据列的访问控制程序,虽然已经到了深夜1点多了,还是硬着头皮把程序都调整好,文档都写好,明天客户上班了,就可以看到例子程序了,希望能满足客户的实际需要。

 

 其实权限的存储,看透了,也是很简单的事情,就是 “什么对象对什么资源有什么权限?”把这个逻辑关系能保存好就ok了,你这样设计了,别人也容易阅读你的程序,容易理解你的数据库设计,将来也容易维护一些。

   用一个思想,前后不矛盾的,把整个系统实现出来,也有些不容易,很多环节会出现前后矛盾,思路混乱的情况,所以时刻要提醒自己,自己的权限系统是按“什么对象对什么资源有什么权限?”的指导思想设计的,若有违背了这个思想,那就仔细深入思考,再重新整理思路。

 

什么对象:在系统里确定各种对象的唯一性,需要2个参数,一个是对象的类别,一个是对象的主键,就像是ERP里的入库单(单号)。

什么资源:什么资源,也是一样的,也需要一个分类,一个主键来识别资源的唯一性。

什么权限:最简单的做法,就是有一个权限表,只用主键来识别唯一性,而不是用“哪个模块+哪个功能”来识别权限,那样做过于繁琐了,将来的扩展性、可维护性都会很差一些,不能灵活适应各种复杂的情况。

 

那表格列的控制,也是一样的道理,应该有一个权限定义,这个权限叫“表格列访问控制”,什么对象是指用户还是角色,对什么资源是指各个表的列。

 

那有一个问题需要解决:这么多表,都有哪些字段?若都靠人工输入,那真的是搞死人,不准确不说,需要反复输入,反复维护,除非有超级耐心,否则难做到准确性、高效性;解决问题的思路是:“我们不是设计了详细的PowerDesigner数据模型吗?不仅仅拿这个生成代码,还可以生成数据表字段的说明文档

 

1:首先需要定义一个权限,这个权限叫“表格列访问控制”。

 

2:我们在PowerDesigner里辛苦设计了表的结构,各个字段的注释等,那先有设计后有实现的原理,数据库里都有什么表、什么字段,应该能从这个设计里自动生成,而不是要人工再输入数据。

 

3:那我们重复利用这个良好的设计,改进一下代码生成,让代码生成器自动生成这些表的,字段说明。

 

4:那我们运行一下这些能自动经产生好表结构说明的程序,那我们就可以得到设置里的内容了。

代码
         ///   <summary>
        
///  自动生成设置表字段
        
///   </summary>
         private   void  SetTableColumns()
        {
            
this .UserCenterDbHelper.Open();
            BaseRoleManager roleManager 
=   new  BaseRoleManager( this .UserCenterDbHelper,  this .UserInfo);
            roleManager.SetTableColumns();

            BaseUserManager userManager 
=   new  BaseUserManager( this .UserCenterDbHelper,  this .UserInfo);
            userManager.SetTableColumns();

            BaseStaffManager staffManager 
=   new  BaseStaffManager( this .UserCenterDbHelper,  this .UserInfo);
            staffManager.SetTableColumns();

            BaseModuleManager moduleManager 
=   new  BaseModuleManager( this .UserCenterDbHelper,  this .UserInfo);
            moduleManager.SetTableColumns();

            
this .UserCenterDbHelper.Close();
        }

 

5:那运行好后,数据库里,就会有表结构的字段说明数据(这些都是代码自动生成的,靠人工输入会搞死人的,表结构有变化了,重新运行一次就OK了,省事了,彻底可以做到全自动化了,爽啊)。

 

6:在运行权限设置页面,用户、角色的字段访问权限可以进行设置了。

 

7:设置用户的字段访问权限效果图如下:

 

8:在没控制表格列的访问控制时,运行效果如下:

 

9:按权限控制后,显示出来的表格为,没有允许访问的字段,不是公开的字段,就无法看到了,都被隐藏掉了:

 

10:数据列的权限控制代码如下参考:

代码
// ------------------------------------------------------------
//  All Rights Reserved , Copyright (C) 2010 , Jirisoft , Ltd. 
// ------------------------------------------------------------

using  System;
using  System.Data;
using  System.Web.UI.WebControls;

namespace  DotNet.Web.Permission
{
    
using  DotNet.Business;
    
using  DotNet.Manager;
    
using  DotNet.Utilities;

    
///   <remarks>
    
///  TableColumns
    
///  表字段权限的例子
    
///  
    
///  修改纪录
    
///  
    
///     版本:1.0 2010.07.13    JiRiGaLa    写好例子程序方便别人学习。
    
///     
    
///  版本:1.0
    
///  
    
///   <author>
    
///          <name> JiRiGaLa </name>
    
///          <date> 2010.07.13 </date>
    
///   </author>  
    
///   </remarks>
     public   partial   class  TableColumns : BasePage
    {
        
protected   void  Page_Load( object  sender, EventArgs e)
        {
            
//  当然是用户需要登录,否则哪里能知道,现在是判断谁的权限啊?
             this .UserInfo  =  Utilities.Login( " Jirigala_Bao@Hotmail.com " , String.Empty);
            
//  设置表字段
            
//  this.SetTableColumns();

            
//  先设置表格的字段状态
             this .CheckUserTableColumnsPermission();
            
//  显示用户
             this .GeUserList();
        }

        
///   <summary>
        
///  自动生成设置表字段
        
///   </summary>
         private   void  SetTableColumns()
        {
            
this .UserCenterDbHelper.Open();
            BaseRoleManager roleManager 
=   new  BaseRoleManager( this .UserCenterDbHelper,  this .UserInfo);
            roleManager.SetTableColumns();

            BaseUserManager userManager 
=   new  BaseUserManager( this .UserCenterDbHelper,  this .UserInfo);
            userManager.SetTableColumns();

            BaseStaffManager staffManager 
=   new  BaseStaffManager( this .UserCenterDbHelper,  this .UserInfo);
            staffManager.SetTableColumns();

            BaseModuleManager moduleManager 
=   new  BaseModuleManager( this .UserCenterDbHelper,  this .UserInfo);
            moduleManager.SetTableColumns();

            
this .UserCenterDbHelper.Close();
        }

        
private   void  GeUserList()
        {
            
//  获取用户列表
            BaseUserManager userManager  =   new  BaseUserManager();
            DataTable dataTable 
=  userManager.GetDT();
            
this .grvUser.DataSource  =  dataTable;
            
this .grvUser.DataBind();
        }

        
private   void  CheckUserTableColumnsPermission()
        {
            
//  当前用户能访问那些字段?
             this .UserCenterDbHelper.Open();
            BaseTableColumnsManager tableColumnsManager 
=   new  BaseTableColumnsManager( this .UserCenterDbHelper, UserInfo);
            DataTable dataTable 
=  tableColumnsManager.GetTableColumns( this .UserInfo.Id,  " Base_User " );
            
this .UserCenterDbHelper.Close();

            
for  ( int  i  =   0 ; i  <   this .grvUser.Columns.Count; i ++ )
            {
                
if  ( this .grvUser.Columns[i]  is  BoundField)
                {
                    BoundField boundField 
=  (BoundField) this .grvUser.Columns[i];
                    
//  这个字段是否可以查看?
                    boundField.Visible  =  BaseBusinessLogic.Exists(dataTable, BaseTableColumnsTable.FieldColumnCode, boundField.DataField);
                }
            }
        }
    }
}

本文转自jirigala_bao 51CTO博客,原文链接:http://blog.51cto.com/jirigala/806831
相关实践学习
消息队列+Serverless+Tablestore:实现高弹性的电商订单系统
基于消息队列以及函数计算,快速部署一个高弹性的商品订单系统,能够应对抢购场景下的高并发情况。
云安全基础课 - 访问控制概述
课程大纲 课程目标和内容介绍视频时长 访问控制概述视频时长 身份标识和认证技术视频时长 授权机制视频时长 访问控制的常见攻击视频时长
相关文章
|
3月前
.NET 4.0下实现.NET4.5的Task类相似功能组件
【10月更文挑战第29天】在.NET 4.0 环境下,可以使用 `BackgroundWorker` 类来实现类似于 .NET 4.5 中 `Task` 类的功能。`BackgroundWorker` 允许在后台执行耗时操作,同时不会阻塞用户界面线程,并支持进度报告和取消操作。尽管它有一些局限性,如复杂的事件处理模型和不灵活的任务管理方式,但在某些情况下仍能有效替代 `Task` 类。
|
8月前
|
搜索推荐 API C#
.NET开源快速、强大、免费的电子表格组件
.NET开源快速、强大、免费的电子表格组件
125 0
|
5月前
|
前端开发 数据安全/隐私保护 UED
.NET 8 通用权限框架 前后端分离,开箱即用
【8月更文挑战第1天】基于.NET 8 的通用权限框架,采用前后端分离设计,实现真正的开箱即用!无需繁琐配置,一键启动权限管理新体验。利用.NET 8 的高性能与稳定性,结合灵活的前后端开发模式,显著提升开发效率,缩短项目周期。无论大小项目,皆能轻松应对,立即体验高效开发的新篇章!
125 1
|
6月前
|
存储 开发框架 前端开发
基于Lumisoft.NET组件,使用IMAP协议收取邮件
基于Lumisoft.NET组件,使用IMAP协议收取邮件
|
5月前
|
存储 开发框架 .NET
ASP.NET Web Api 使用 EF 6,DateTime 字段如何取数据库服务器当前时间
ASP.NET Web Api 使用 EF 6,DateTime 字段如何取数据库服务器当前时间
|
5月前
|
程序员 数据库
分享 2 个 .NET EF 6 只更新某些字段的方法
分享 2 个 .NET EF 6 只更新某些字段的方法
124 0
|
6月前
|
存储 对象存储 Python
`openpyxl`是一个用于读写Excel 2010 xlsx/xlsm/xltx/xltm文件的Python库。它不需要Microsoft Excel,也不需要.NET或COM组件。
`openpyxl`是一个用于读写Excel 2010 xlsx/xlsm/xltx/xltm文件的Python库。它不需要Microsoft Excel,也不需要.NET或COM组件。
|
7月前
|
NoSQL 大数据 Redis
分享5款.NET开源免费的Redis客户端组件库
分享5款.NET开源免费的Redis客户端组件库
113 1
|
10天前
|
监控 前端开发 API
一款基于 .NET MVC 框架开发、功能全面的MES系统
一款基于 .NET MVC 框架开发、功能全面的MES系统
|
4月前
|
开发框架 前端开发 JavaScript
ASP.NET MVC 教程
ASP.NET 是一个使用 HTML、CSS、JavaScript 和服务器脚本创建网页和网站的开发框架。
51 7