博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Enterprise Library 2.0 -- Security Application Block
阅读量:6242 次
发布时间:2019-06-22

本文共 6626 字,大约阅读时间需要 22 分钟。

       今天来介绍一下Enterprise Library 2.0中的Security Application Block ,它可以帮助程序开发者在应用程序中实现与授权有关的大部分功能,不仅如此,它还支持缓存我们系统中用户的授权以及,授权数据。主要包括一下几个部分的功能:

1、减少代码编写量;
2、保持应用程序中安全管理的一致性;
3、提供了应用程序中很多安全问题的实现方法;
4、可扩展,支持自定义Provider。
...

       关于Security Application Block的介绍部分,我不再多说,具体可以参考帮助文档。下面我们来看一下如何配置Security Application Block,首先打开配置工具,新建一个Security Application Block,如下:

641.gif
然后在Authorization节点下创建一个Authorization Rule Provider,名称为RuleProvider,如下:
642.gif
现在就可以在RuleProvider节点下,创建一系列的规则(Rule)了。如下图:
643.gif
新建了规则,我们还需要为这个规则定义一个表达式,用于在程序中判断是否满足该规则,如下图:
644.gif
如图所示,我们定义了能通过该规则的用户的身份必须是User或Admin.我们可以根据我们的实际需要定义各种各样的规则。
最后我们可以为我们建立的Security Application Block分配一个默认的Authorization实例,如图:
645.gif
此时,我们的配置文件中就多了如下内容:

None.gif
<
section 
name
="securityConfiguration"
 type
="Microsoft.Practices.EnterpriseLibrary.Security.Configuration.SecuritySettings, Microsoft.Practices.EnterpriseLibrary.Security, Version=2.0.0.0, Culture=neutral, PublicKeyToken=null"
 
/>
None.gif
None.gif
<
securityConfiguration 
defaultAuthorizationInstance
="RuleProvider"
None.gif    defaultSecurityCacheInstance
=""
>
None.gif    
<
authorizationProviders
>
None.gif      
<
add 
type
="Microsoft.Practices.EnterpriseLibrary.Security.AuthorizationRuleProvider, Microsoft.Practices.EnterpriseLibrary.Security, Version=2.0.0.0, Culture=neutral, PublicKeyToken=null"
None.gif        name
="RuleProvider"
>
None.gif        
<
rules
>
None.gif          
<
add 
expression
="R:User OR R:Admin"
 name
="Rule"
 
/>
None.gif        
</
rules
>
None.gif      
</
add
>
None.gif    
</
authorizationProviders
>
None.gif  
</
securityConfiguration
>

       关于Security Application Block的配置就说到这里。

      下面来看看Enterprise Library 2.0 的Security Application Block 与1.0版本中的一点区别,因为ASP.NET2.0中提供了角色与成员管理的新特性,所以在某些方面和1.0版本还是有一定的区别:

    因为ASP.NET2.0提供了MemberShip,Roles两个类,其中包含了验证用户、角色管理以及对Profile信息的设置与读取功能,所以Security Application Block 2.0将这些功能去掉了。因此和1.0版本的主要区别在于下面三方面:
首先导入下面两个命名空间:
using System.Web.Profile;
using System.Web.Security;
1、验证用户的方法如下:

ExpandedBlockStart.gif
ContractedBlock.gif
        
/**/
/// <summary>
InBlock.gif        
/// 验证用户
InBlock.gif        
/// http://pw.cnblogs.com
InBlock.gif        
/// </summary>
InBlock.gif        
/// <param name="username">用户名</param>
InBlock.gif        
/// <param name="password">密码</param>
ExpandedBlockEnd.gif        
/// <returns></returns>
None.gif
        
public
 
bool
 CheckUser(
string
 username, 
string
 password)
ExpandedBlockStart.gifContractedBlock.gif        
dot.gif
{
InBlock.gif            
return Membership.ValidateUser(username, password);
ExpandedBlockEnd.gif        }

2、读取或设置Profile信息

ExpandedBlockStart.gif
ContractedBlock.gif
        
/**/
/// <summary>
InBlock.gif        
/// 使用 Profile
InBlock.gif        
/// http://pw.cnblogs.com
ExpandedBlockEnd.gif        
/// </summary>
None.gif
        [TestMethod]
None.gif        
public
 
void
 UseProfile()
ExpandedBlockStart.gifContractedBlock.gif        
dot.gif
{
InBlock.gif            IIdentity identity;
InBlock.gif            identity 
= new GenericIdentity("SHY520", Membership.Provider.Name);
InBlock.gif
InBlock.gif            
//设置Profile
InBlock.gif
            ProfileBase setuserProfile = ProfileBase.Create(identity.Name);
InBlock.gif
InBlock.gif            setuserProfile[
"Name"= "SHY520";
InBlock.gif            setuserProfile[
"Address"= "Wuhu China";
InBlock.gif            
//保存Profile信息
InBlock.gif
            setuserProfile.Save();
InBlock.gif
InBlock.gif            
//读取Profile信息
InBlock.gif
            ProfileBase readuserProfile = ProfileBase.Create(identity.Name);
InBlock.gif
InBlock.gif            
string Name = readuserProfile["Name"].ToString();
InBlock.gif            
string Address = readuserProfile["Address"].ToString();
InBlock.gif
InBlock.gif            Assert.AreEqual(Name,
"SHY520");
InBlock.gif            Assert.AreEqual(Address,
"Wuhu China");
ExpandedBlockEnd.gif        }

3、得到某个用户所属角色列表

ExpandedBlockStart.gif
ContractedBlock.gif
        
/**/
/// <summary>
InBlock.gif        
/// 得到某用户所属角色列表
InBlock.gif        
/// http://pw.cnblogs.com
InBlock.gif        
/// </summary>
ExpandedBlockEnd.gif        
/// <returns>角色列表</returns>
None.gif
        
public
 
string
[] GetUserRoles()
ExpandedBlockStart.gifContractedBlock.gif        
dot.gif
{
InBlock.gif            IIdentity identity 
= new GenericIdentity("SHY520", Membership.Provider.Name);
InBlock.gif
InBlock.gif            
return Roles.GetRolesForUser(identity.Name);
InBlock.gif
ExpandedBlockEnd.gif        }

      与上一个版本的区别基本上就是以上几点,下面我们来看看Security Application Block2.0的基本使用方法:

1、为已授权的用户分配一个Token(记号):

       Security Application Block将授权用户的身份信息放进缓存,并返回一个Token,所以我们在使用此方之前需要先配置一个Security Cache,具体方法我就不多说了,可以参考官方教程,下面贴出配置后的App.Config中的代码:

None.gif
<
securityCacheProviders
>
None.gif      
<
add 
cacheManagerInstanceName
="Cache Manager"
 defaultSlidingSessionExpirationInMinutes
="10"
None.gif        defaultAbsoluteSessionExpirationInMinutes
="60"
 type
="Microsoft.Practices.EnterpriseLibrary.Security.Cache.CachingStore.CachingStoreProvider, Microsoft.Practices.EnterpriseLibrary.Security.Cache.CachingStore, Version=2.0.0.0, Culture=neutral, PublicKeyToken=null"
None.gif        name
="Caching Store Provider"
 
/>
None.gif
</
securityCacheProviders
>

这段代码是在securityConfiguration节中的,其中cacheManagerInstanceName是我们在Caching Application Block中配置的实例。

ExpandedBlockStart.gif
ContractedBlock.gif
        
/**/
/// <summary>
InBlock.gif        
/// 使用SaveIdentity方法,保存用户身份,并返回一个Token
InBlock.gif        
/// http://pw.cnblogs.com
InBlock.gif        
/// </summary>
ExpandedBlockEnd.gif        
/// <returns></returns>
None.gif
        
public
 IToken SaveUserInfo()
ExpandedBlockStart.gifContractedBlock.gif        
dot.gif
{
InBlock.gif            ISecurityCacheProvider sc 
= SecurityCacheFactory.GetSecurityCacheProvider("Cache Manager");
InBlock.gif
InBlock.gif            
//将用户身份装入缓存,并返回一个IToken类型的记号
InBlock.gif
            return sc.SaveIdentity(new GenericIdentity("SHY520"));
ExpandedBlockEnd.gif        }

2、使用Token来验证用户是否已被授权

ExpandedBlockStart.gif
ContractedBlock.gif
        
/**/
/// <summary>
InBlock.gif        
/// 根据Token来判断用户是否已被授权
InBlock.gif        
/// http://pw.cnblogs.com
InBlock.gif        
/// </summary>
InBlock.gif        
/// <param name="token"></param>
ExpandedBlockEnd.gif        
/// <returns></returns>
None.gif
        
public
 
bool
 CheckUserByToken(IToken token)
ExpandedBlockStart.gifContractedBlock.gif        
dot.gif
{
InBlock.gif            ISecurityCacheProvider sc 
= SecurityCacheFactory.GetSecurityCacheProvider("Cache Manager");
InBlock.gif
InBlock.gif            
//得到Token对应的身份IIdentity
InBlock.gif
            IIdentity savedIdentity = sc.GetIdentity(token);
InBlock.gif            
//返回该身份是否已被授权
InBlock.gif
            return savedIdentity.IsAuthenticated;
InBlock.gif            
ExpandedBlockEnd.gif        }
   

3、结束User Session(即使Token过期)

ExpandedBlockStart.gif
ContractedBlock.gif
        
/**/
///
 
<summary>
InBlock.gif        
///
 使用户Token过期
InBlock.gif        
///
 
http://pw.cnblogs.com
ExpandedBlockEnd.gif        
///
 
</summary>
None.gif
        
public
 
void
 CloseUserSession()
ExpandedBlockStart.gifContractedBlock.gif        
dot.gif
{
InBlock.gif            ISecurityCacheProvider sc 
= SecurityCacheFactory.GetSecurityCacheProvider("Cache Manager");
InBlock.gif            
//保存身份
InBlock.gif
            IToken token = sc.SaveIdentity(new GenericIdentity("SHY520"));
InBlock.gif            
//使身份过期
InBlock.gif
            sc.ExpireIdentity(token);
ExpandedBlockEnd.gif        }

4、判断用户是否满足一定的规则

      首先需要导入下面的命名空间:
 using System.Security;
 using System.Security.Principal;
 using Microsoft.Practices.EnterpriseLibrary.Security;

ExpandedBlockStart.gif
ContractedBlock.gif
    
/**/
/// <summary>
InBlock.gif        
/// 判断用户是否满足一定的规则
InBlock.gif        
/// http://pw.cnblogs.com
InBlock.gif        
/// </summary>
InBlock.gif        
/// <param name="username">用户名称</param>
InBlock.gif        
/// <param name="role">角色名称</param>
InBlock.gif        
/// <param name="rule">规则名称</param>
ExpandedBlockEnd.gif        
/// <returns></returns>
None.gif
        
public
 
bool
 CheckUserRoleByRule(
string
 username, 
string
 role, 
string
 rule)
ExpandedBlockStart.gifContractedBlock.gif        
dot.gif
{
ExpandedSubBlockStart.gifContractedSubBlock.gif            IPrincipal principal 
= new GenericPrincipal(new GenericIdentity(username), new string[] dot.gif{ role });
InBlock.gif
InBlock.gif            
//创建一个默认的Authorization实例
InBlock.gif
            IAuthorizationProvider autoprovider = AuthorizationFactory.GetAuthorizationProvider();
InBlock.gif
InBlock.gif            
//返回验证是否通过
InBlock.gif
            return autoprovider.Authorize(principal, rule);
ExpandedBlockEnd.gif        }

通过上面的方法可以很简单的实现对用户权限的鉴定,关于Security Application Block的简单应用就说到这里,下面我们来看一下如何实现自定义的authorization provider。

1、首先我们建立自己的Provider类,该类需继承AuthorizationProvider;
2、并且要加上[ConfigurationElementType(typeof(CustomAuthorizationProviderData))]的Attribute;
3、添加构造函数,参数为NameValueCollection类型;
4、覆盖基类中的Authorize方法,在其中添加自己的验证是否授权的逻辑
这样就完成了一个自定义的authorization provider。
完整的类定义如下:

None.gif
using
 System;
None.gif
using
 System.Collections.Generic;
None.gif
using
 System.Text;
None.gif
using
 Microsoft.Practices.EnterpriseLibrary.Security;
None.gif
using
 System.Collections.Specialized;
None.gif
using
 System.Security.Principal;
None.gif
using
 Microsoft.Practices.EnterpriseLibrary.Common.Configuration;
None.gif
using
 Microsoft.Practices.EnterpriseLibrary.Security.Configuration;
None.gif
None.gif
namespace
 Enterprise_Library_2
ExpandedBlockStart.gifContractedBlock.gif
dot.gif
{
InBlock.gif    [ConfigurationElementType(
typeof(CustomAuthorizationProviderData))]
InBlock.gif    
public class CustomProvider : AuthorizationProvider
ExpandedSubBlockStart.gifContractedSubBlock.gif    
dot.gif{
InBlock.gif        
public CustomProvider(NameValueCollection configurationItems)
ExpandedSubBlockStart.gifContractedSubBlock.gif        
dot.gif{
InBlock.gif            
ExpandedSubBlockEnd.gif        }
InBlock.gif
InBlock.gif        
public override bool Authorize(IPrincipal principal, string context)
ExpandedSubBlockStart.gifContractedSubBlock.gif        
dot.gif{
InBlock.gif            
//TODO:在此处添加自己需要的验证授权的逻辑既可
InBlock.gif
InBlock.gif            
return true;
ExpandedSubBlockEnd.gif        }
InBlock.gif
ExpandedSubBlockEnd.gif    }
ExpandedBlockEnd.gif}

关于Security Application Block的介绍就说到这里了,有疏忽错误的地方,还请指正,希望对初学者有所帮助!

Email:pwei013@163.com

你可能感兴趣的文章
SQL SERVER IN参数化处理
查看>>
Python MongoDB Spatial Query
查看>>
NetBeans IDE 7.4 Beta版本build JavaFX时生成的可执行jar包执行时找不到依赖的jar包
查看>>
笔记本wifi热点设置好后,手机连上但不能上网问题
查看>>
Run ASP.NET MVC site on mac (mono/xamarin studio)
查看>>
win8.1安装驱动出现“文件的哈希值不在指定的目录”的解决办法[zz]
查看>>
CRM 常用SQL 脚本
查看>>
备忘录--关于线程和IO知识
查看>>
【iCore3 双核心板】例程八:定时器PWM实验——呼吸灯
查看>>
jquery tmpl 详解
查看>>
docker学习笔记4:利用docker hub上的mysql镜像创建mysql容器
查看>>
【Xamarin开发 Android 系列 3】循序渐进的学习顺序
查看>>
自定义列表dl的使用原因和场合
查看>>
Oracle11G 卸载步骤
查看>>
PHP递归生成树形数组
查看>>
学习RSA公开密钥算法
查看>>
教你摆脱低级程序猿 项目中cocopads的安装使用
查看>>
禁止火狐浏览器缓存input标签方法
查看>>
[ilink32 Error] Error: Unresolved external '__fastcall Data::Win::Adodb::TCustomADODataSet
查看>>
.NET Core:面向未来的开源跨平台开发技术
查看>>