ASP.NET通用权限组件实现一

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

开篇

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

配置文件

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

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

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

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

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

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

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

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

 1 <Permission>
 2     <!--做权限验证的页面(.开始表示后缀名通配规则,/开始表示目录通配,/结束标志包含子目录)-->
 3     <PermissionPage>
 4       <add value="/Manage" />
 5       <add value=".aspx" />
 6       <add value=".ashx" />
 7     </PermissionPage>
 8     <!--不作权限和登录验证的页面(.开始表示后缀名通配规则,/开始表示目录通配,/结束标志包含子目录)-->
 9     <Ignore>
10       <add value="/Manage/Default.aspx" />
11       <add value="/Manage/Login.aspx" />
12       <add value="/Manage/VerifyCode.aspx" />
13     </Ignore>
14     <!--查询URL记录的SQL语句(可以有多个,只要有一个语句查询到记录即可,只有能查询到记录的URL请求才会进行权限验证)-->
15     <PermissionUrlSQL>
16       <!--查询权限SQL语句-->
17       <CommandText value="select A.FID from Man_Function A where A.FURL=@FURL" />
18       <Parameter>
19         <!--SQL语句参数名-->
20         <ParameterName value="@FURL" />
21         <!--SQL语句参数类型-->
22         <DBType value="VarChar" />
23         <!--SQL语句参数要取的Session名称([PageName]表示取URL的字符串)-->
24         <SessionName value="PageName" />
25       </Parameter>
26     </PermissionUrlSQL>
27     <!--权限验证SQL语句(可以有多个,只要有一个语句验证有权限则可以通过)-->
28     <PermissionSQL>
29       <!--查询权限SQL语句-->
30       <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" />
31       <Parameter>
32         <!--SQL语句参数名-->
33         <ParameterName value="@EmpCode" />
34         <!--SQL语句参数类型-->
35         <DBType value="VarChar" />
36         <!--SQL语句参数要取的Session名称([PageName]表示取URL的字符串)-->
37         <SessionName value="SysUserCode" />
38       </Parameter>
39       <Parameter>
40         <!--SQL语句参数名-->
41         <ParameterName value="@FURL" />
42         <!--SQL语句参数类型-->
43         <DBType value="VarChar" />
44         <!--SQL语句参数要取的Session名称([PageName]表示取URL的字符串)-->
45         <SessionName value="PageName" />
46       </Parameter>
47     </PermissionSQL>
48     <!--查询URL子项记录的SQL语句(可以有多个,只要有一个语句查询到记录即可,只有能查询到记录的URL请求才会进行权限验证,通常情况是权限需要控制到按钮时需要的)-->
49     <ChildUrlSQL>
50       <!--查询权限SQL语句-->
51       <CommandText value="select A.FID from Man_Function A where A.FID=@FID" />
52       <Parameter>
53         <!--SQL语句参数名-->
54         <ParameterName value="@FID" />
55         <!--SQL语句参数类型-->
56         <DBType value="Int" />
57         <!--SQL语句参数要取的Session名称([PageName]表示取URL的字符串)-->
58         <SessionName value="PageName" />
59         <!--SQL语句参数要取的列名称(PermissionSQL结点中SQL语句的列,[PageName]表示取URL的字符串),和SessionName节点不能同事存在-->
60         <ColumnName value="FID" />
61       </Parameter>
62     </ChildUrlSQL>    
63     <!--菜单的子项查询(通常情况是权限需要控制到按钮时需要的)-->
64     <ChildSQL>
65       <!--查询SQL语句-->
66       <CommandText value="select A.FID from Man_Function A where A.FID=@FID" />
67       <Parameter>
68         <!--SQL语句参数名-->
69         <ParameterName value="@FID" />
70         <!--SQL语句参数类型-->
71         <DBType value="Int" />
72         <!--SQL语句参数要取的Session名称-->
73         <SessionName value="DateTime" />
74         <!--SQL语句参数要取的列名称(PermissionSQL结点中SQL语句的列,[PageName]表示取URL的字符串),和SessionName节点不能同事存在-->
75         <ColumnName value="FID" />
76       </Parameter>
77       <!--按钮权限标志的列名称,这个值是要和前台页面元素的[sfcode]的值所对应的-->
78       <ButtonFlagColumn value="FID" />
79     </ChildSQL>  
80 </Permission>

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

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

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

ASP.NET通用权限组件实现一,古老的榕树,5-wow.com

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。