ASP.NET通用权限组件实现一
沙发(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通用权限组件实现一的更多相关文章
- ASP.NET通用权限组件思路设计
开篇 做任何系统都离不开和绕不过权限的控制,尤其是B/S系统工作原理的特殊性使得权限控制起来更为繁琐,所以就在想是否可以利用IIS的工作原理,在IIS处理客户端请求的某个入口或出口通过判断URL来达到 ...
- ASP.NET通用权限系统快速开发框架
系统在线演示地址: http://120.90.2.126:8051 登录账户:system,密码:system### DEMO下载地址: http://download.csdn.net/detai ...
- ASP.NET通用权限验证组件实现
沙发(SF)通用权限验证组件 开篇 本篇介绍通用权限验证的实现代码思路,总共分为导入参数.解析XML.根据XML配置进行处理.返回结果. 代码架构图 1. 类介绍 1.SFWebPermissio ...
- ASP.NET通用权限框架 权限管理系统源码jquery 精美UI源码
软件技术开发,合作请联系QQ:858-048-581 开发工具 VS2010 .sql2005.2008等(在Sql server数据执行脚本即可) VS2010 打开保证本地运行成功(数据库.源代 ...
- asp.net MVC通用权限管理系统-响应式布局-源码
一.Angel工作室简单通用权限系统简介 AngelRM(Asp.net MVC Web api)是基于asp.net(C#)MVC+前端bootstrap+ztree+lodash+jquery技术 ...
- 基于asp.net(C#)MVC+前端bootstrap+ztree+lodash+jquery技术-Angel工作室通用权限管理
一.Angel工作室简单通用权限系统简介 AngelRM(Asp.net MVC Web api)是基于asp.net(C#)MVC+前端bootstrap+ztree+lodash+jquery技术 ...
- ASP.NET MVC通用权限管理系统(响应布局)源码更新介绍
一.asp.net mvc 通用权限管理系统(响应布局)源码主要以下特点: AngelRM(Asp.net MVC)是基于asp.net(C#)MVC+前端bootstrap+ztree+lodash ...
- asp.net MVC通用分页组件 使用方便 通用性强
asp.net MVC通用分页组件 使用方便 通用性强 该分页控件的显示逻辑: 1 当前页面反色突出显示,链接不可点击 2 第一页时首页链接不可点击 3 最后一页时尾页链接不可点击 4 当前页面左 ...
- FineAdmin.Mvc 使用ok-admin+ASP.NET MVC搭建的通用权限后台管理系统
FineAdmin.Mvc 介绍 使用ok-admin+ASP.NET MVC搭建的通用权限后台管理系统RightControl后台layui模板不太好看,换成ok-admin v2.0重写一遍.项目 ...
随机推荐
- 16. Linux 文件目录权限
# 文件参数 d:表示是一个目录-:表示这是一个普通的文件l: 表示这是一个符号链接文件,实际上它指向另一个文件b.c:分别表示区块设备和其他的外围设备,是特殊类型的文件s.p:这些文件关系到系统的数 ...
- EffectiveC#01--避免返回内部类对象的引用
此篇是对00中第3点的再一次阐述. 1.如果一个属性返回一个引用类型,那么调用者就可以访问这个对象的公共成员,也包括修改这些属性的状态. public class MyBusinessObject { ...
- 表单元素-select
<form> <select size="2"> <option value="JMS HADEN">JMS HADEN&l ...
- bootstrap 常用类名
一. 常用类1.container居中的内容展示2.row 行内容显示3.col 列内容显示, 列必须在row 中xs 宽度小于768 ,sm宽度小于990 大于768 ,md 宽度大于990,小于 ...
- 如何禁用Visual Studio 2013的Browser Link功能
VS2013新增的Browser Link功能虽然“强大”,但我并不需要. 但默认是开启的,会在页面中自动添加如下的代码,真是烦人! <!-- Visual Studio Browser Lin ...
- VS2015预览版中的C#6.0 新功能(一)
VS2015预览版中的C#6.0 新功能(二) VS2015预览版中的C#6.0 新功能(三) VS2015的预览版在11月12日发布了,下面让我们来看看C#都提供了哪些新的功能. 字符串添写(Str ...
- Unity轻量级依赖注入容器
一.前言 Unity是一个轻量级的可扩展的依赖注入容器,支持构造函数,属性和方法调用注入.在Nuget里安装unity
- FZU1327 优先队列
Problem 1327 Blocks of Stones II Accept: 318 Submit: 881Time Limit: 1000 mSec Memory Limit : 3 ...
- (转) int argc, char* argv[] 的用法
int main(int argc, char* argv[]) 這兩個參數的作用是什麼呢?argc 是指命令行輸入參數的個數,argv存儲了所有的命令行參數.假如你的程式是hello.exe,如果在 ...
- hdu3830 (二分+LCA)
转载请注明出处: http://www.cnblogs.com/fraud/ ——by fraud Checkers Time Limit: 2000/1000 MS (Java/O ...