沙发(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语句配置,如果只是做简单的登录验证也可以删除这两个节点。
下一篇文章将介绍组件的整体结构和实现,具体的编码工作也已经完成,初步测试了一下还可以。
新闻热点
疑难解答