沙发(SF)通用权限验证组件

开篇

上一篇提到了通用权限的设计思路,根据设计思路一步一步的来实现一个相对通用的权限验证组件。在VS2010下用C#语言基于.net framework2.0框架实现具体功能。

配置文件

配置文件为XML格式(SFPermission.xml)公有四个节点分类:

一、AppSet节点:此节点配置一些基础信息。

 <AppSet>
<!--数据库节点名称(必须在Web.config的connectionStrings节点下面)-->
<add key="DataConnName" value="ConnString"/>
<!--数据库连接字符串(DataConnName和ConnString节点只要有一个存在即可)-->
<add key="ConnString" value="数据库连接字符串"/>
<!--页面截取规则(0:只截取文件名,1:截取全路径,2:截取全路径(单文件去掉第一个[/]、包含路径的保留第一个[/]),可以在Page节点配置例外)-->
<add key="PageAllPath" value="2"/>
<!--未登录时的返回页面(登录验证为通过或SQL语句参数要取的Session值为空或不存在)-->
<add key="OutLogin" value="未登录时的输出信息"/>
<!--登录验证的Session名称-->
<add key="LoginSessionName" value="SysUserCode"/>
</AppSet>

二、MessageSet节点:没有权限时提示信息的配置。

 <MessageSet>
<!--没有权限时的配置信息(Key为后缀名[后缀名为通配]或文件名,value为需要输出的文本)-->
<add key=".aspx" value="没有权限"/>
<!--没有权限时的配置信息(Key为后缀名,value为需要输出的文本)-->
<add key=".ashx" value="没有权限"/>
</MessageSet>

三、Pages节点:配置在截取验证URL的名称时要拼接参数的参数。

 <!--需要连接参数的页面配置(配置的页面将用组合后的整体作为验证权限的页面名称)-->
<Pages>
<!--名称的第一个字符为(点)表示此种后缀名的请求都将连接某参数,value多个参数名用逗号分隔-->
<add key=".ashx" value="Action" />
</Pages>

四、Permission节点:配置需要权限验证的页面、忽略权限验证的页面、权限验证的SQL语句、有权限的子功能(权限控制到按钮时)查询语句。

 <Permission>
<!--做权限验证的页面(.开始表示后缀名通配规则,/开始表示目录通配,/结束标志包含子目录)-->
<PermissionPage>
<add value="/Manage" />
<add value=".aspx" />
<add value=".ashx" />
</PermissionPage>
<!--不作权限和登录验证的页面(.开始表示后缀名通配规则,/开始表示目录通配,/结束标志包含子目录)-->
<Ignore>
<add value="/Manage/Default.aspx" />
<add value="/Manage/Login.aspx" />
<add value="/Manage/VerifyCode.aspx" />
</Ignore>
<!--查询URL记录的SQL语句(可以有多个,只要有一个语句查询到记录即可,只有能查询到记录的URL请求才会进行权限验证)-->
<PermissionUrlSQL>
<!--查询权限SQL语句-->
<CommandText value="select A.FID from Man_Function A where A.FURL=@FURL" />
<Parameter>
<!--SQL语句参数名-->
<ParameterName value="@FURL" />
<!--SQL语句参数类型-->
<DBType value="VarChar" />
<!--SQL语句参数要取的Session名称([PageName]表示取URL的字符串)-->
<SessionName value="PageName" />
</Parameter>
</PermissionUrlSQL>
<!--权限验证SQL语句(可以有多个,只要有一个语句验证有权限则可以通过)-->
<PermissionSQL>
<!--查询权限SQL语句-->
<CommandText value="select A.FID from Man_Function A,Man_Popedom B where A.FID=B.FID AND B.EmpCode=@EmpCode AND A.FURL=@FURL" />
<Parameter>
<!--SQL语句参数名-->
<ParameterName value="@EmpCode" />
<!--SQL语句参数类型-->
<DBType value="VarChar" />
<!--SQL语句参数要取的Session名称([PageName]表示取URL的字符串)-->
<SessionName value="SysUserCode" />
</Parameter>
<Parameter>
<!--SQL语句参数名-->
<ParameterName value="@FURL" />
<!--SQL语句参数类型-->
<DBType value="VarChar" />
<!--SQL语句参数要取的Session名称([PageName]表示取URL的字符串)-->
<SessionName value="PageName" />
</Parameter>
</PermissionSQL>
<!--查询URL子项记录的SQL语句(可以有多个,只要有一个语句查询到记录即可,只有能查询到记录的URL请求才会进行权限验证,通常情况是权限需要控制到按钮时需要的)-->
<ChildUrlSQL>
<!--查询权限SQL语句-->
<CommandText value="select A.FID from Man_Function A where A.FID=@FID" />
<Parameter>
<!--SQL语句参数名-->
<ParameterName value="@FID" />
<!--SQL语句参数类型-->
<DBType value="Int" />
<!--SQL语句参数要取的Session名称([PageName]表示取URL的字符串)-->
<SessionName value="PageName" />
<!--SQL语句参数要取的列名称(PermissionSQL结点中SQL语句的列,[PageName]表示取URL的字符串),和SessionName节点不能同事存在-->
<ColumnName value="FID" />
</Parameter>
</ChildUrlSQL>
<!--菜单的子项查询(通常情况是权限需要控制到按钮时需要的)-->
<ChildSQL>
<!--查询SQL语句-->
<CommandText value="select A.FID from Man_Function A where A.FID=@FID" />
<Parameter>
<!--SQL语句参数名-->
<ParameterName value="@FID" />
<!--SQL语句参数类型-->
<DBType value="Int" />
<!--SQL语句参数要取的Session名称-->
<SessionName value="DateTime" />
<!--SQL语句参数要取的列名称(PermissionSQL结点中SQL语句的列,[PageName]表示取URL的字符串),和SessionName节点不能同事存在-->
<ColumnName value="FID" />
</Parameter>
<!--按钮权限标志的列名称,这个值是要和前台页面元素的[sfcode]的值所对应的-->
<ButtonFlagColumn value="FID" />
</ChildSQL>
</Permission>

其中ChildUrlSQL和ChildSQL节点是在权限验证控制到按钮(功能点)时才用到的,如果只是控制到页面可以删除这两个节点;

PermissionUrlSQL和PermissionSQL节点是控制到页面时的权限验证的SQL语句配置,如果只是做简单的登录验证也可以删除这两个节点。

下一篇文章将介绍组件的整体结构和实现,具体的编码工作也已经完成,初步测试了一下还可以。

ASP.NET通用权限组件实现一的更多相关文章

  1. ASP.NET通用权限组件思路设计

    开篇 做任何系统都离不开和绕不过权限的控制,尤其是B/S系统工作原理的特殊性使得权限控制起来更为繁琐,所以就在想是否可以利用IIS的工作原理,在IIS处理客户端请求的某个入口或出口通过判断URL来达到 ...

  2. ASP.NET通用权限系统快速开发框架

    系统在线演示地址: http://120.90.2.126:8051 登录账户:system,密码:system### DEMO下载地址: http://download.csdn.net/detai ...

  3. ASP.NET通用权限验证组件实现

    沙发(SF)通用权限验证组件 开篇 本篇介绍通用权限验证的实现代码思路,总共分为导入参数.解析XML.根据XML配置进行处理.返回结果. 代码架构图 1.   类介绍 1.SFWebPermissio ...

  4. ASP.NET通用权限框架 权限管理系统源码jquery 精美UI源码

    软件技术开发,合作请联系QQ:858-048-581 开发工具 VS2010 .sql2005.2008等(在Sql server数据执行脚本即可)  VS2010 打开保证本地运行成功(数据库.源代 ...

  5. asp.net MVC通用权限管理系统-响应式布局-源码

    一.Angel工作室简单通用权限系统简介 AngelRM(Asp.net MVC Web api)是基于asp.net(C#)MVC+前端bootstrap+ztree+lodash+jquery技术 ...

  6. 基于asp.net(C#)MVC+前端bootstrap+ztree+lodash+jquery技术-Angel工作室通用权限管理

    一.Angel工作室简单通用权限系统简介 AngelRM(Asp.net MVC Web api)是基于asp.net(C#)MVC+前端bootstrap+ztree+lodash+jquery技术 ...

  7. ASP.NET MVC通用权限管理系统(响应布局)源码更新介绍

    一.asp.net mvc 通用权限管理系统(响应布局)源码主要以下特点: AngelRM(Asp.net MVC)是基于asp.net(C#)MVC+前端bootstrap+ztree+lodash ...

  8. asp.net MVC通用分页组件 使用方便 通用性强

    asp.net MVC通用分页组件 使用方便 通用性强   该分页控件的显示逻辑: 1 当前页面反色突出显示,链接不可点击 2 第一页时首页链接不可点击 3 最后一页时尾页链接不可点击 4 当前页面左 ...

  9. FineAdmin.Mvc 使用ok-admin+ASP.NET MVC搭建的通用权限后台管理系统

    FineAdmin.Mvc 介绍 使用ok-admin+ASP.NET MVC搭建的通用权限后台管理系统RightControl后台layui模板不太好看,换成ok-admin v2.0重写一遍.项目 ...

随机推荐

  1. [跟我学Spring学习笔记][DI配置与使用]

    DI 依赖和依赖注入 定义 传统的依赖一般指"类之间的关系",那先让我们复习一下类之间的关系: 泛化:表示类与类之间的继承关系.接口与接口之间的继承关系: 实现:表示类对接口的实现 ...

  2. WEB服务器2--IIS架构(转)

    开始之前可以先读:http://www.cnblogs.com/tiantianle/p/5419445.html 原文:http://www.cnblogs.com/arbin98/archive/ ...

  3. CSS减肥的工具–Firefox插件 CSS Usage

    首先,我们需要安装Firefox(猛击此处下载),或者确定你已经安装的版本已经高于3.1; 第二步,安装前端开发人员最普及的开发工具 Firebug: 第三步,安装CSS Usage 0.3.4.1: ...

  4. Visual Studio 2013 Web开发、新增功能:“Browser Link”

    微软正式发布Visual Studio 2013 RTM版,微软还发布了Visual Studio 2013的最终版本..NET 4.5.1以及Team Foundation Server 2013. ...

  5. C#winform修改IP,dns

     /// 将IP,DNS设置为自动获取        ///        private void setDHCP()        {            string  _doscmd = & ...

  6. PHP学习笔记三十【final】

    <?php //final不能去修饰属性(变量) //如果希望类不希望被继承就可以使用final关键字 final class Person() { public function sayHi( ...

  7. html链接

    1. <a href="/index.html">本文本</a> 是一个指向本网站中的一个页面的链接.</p><p><a hr ...

  8. QT5.5实现串口通信

    QT5.1以上版本自带QtSerialPort集成库,只要在头文件中集成 #include <QtSerialPort/QSerialPort> #include <QtSerial ...

  9. CAN总线

    1.CAN(controller area network) LAN(local area network)局域网 2.CAN等通信协议的开发,使多种LAN通过网关进行数据交换得以实现.如应用在汽车电 ...

  10. python之3内置容器

    所谓内置容器,就是不需要第三方模块,就可以使用的. 1.list容器,一个有序序列,类似于数组,但比数组强大很多 1.1.如何初始化list,直接一个[]即可,这是一个空的list >>& ...