转自:http://hi.baidu.com/wildwithjoy/blog/item/b5540527dfd72307918f9d30.html
BlogProvider,BlogProviderCollection和blogprovidersection两个类用于定制提供程序
Blogservice类通过对他们的调用来实现对不同的提供程序使用一样的方法调用..
从web.config中读取以下内容
<BlogEngine>
<blogProviderdefaultProvider="XmlBlogProvider">
<providers>
<addname="XmlBlogProvider"type="BlogEngine.Core.Providers.XmlBlogProvider"/>
<addname="MSSQLBlogProvider"type="BlogEngine.Core.Providers.MSSQLBlogProvider"/>
</providers>
</blogProvider>
</BlogEngine>
通过defaultProvider得到提供程序
由于使用了定制配置段,所以该段必须在使用前定义,还必须指定提供该定制段支持的类/类型。下面的代码列出了配置文件中完成这个操作所必需的项:
<configSections>
<sectionGroupname="BlogEngine">
<sectionname="blogProvider"requirePermission="false"type="BlogEngine.Core.Providers.BlogProviderSection, BlogEngine.Core"allowDefinition="MachineToApplication"restartOnExternalChanges="true"/>
</sectionGroup>
</configSections>
BlogEngine.Core.Providers.BlogProviderSection, BlogEngine.Core是访问该段时的处理程序
然后需要建立这个类
public class BlogProviderSection : ConfigurationSection
{
///<summary>
/// A collection of registered providers.
///</summary>
[ConfigurationProperty("providers")]
public ProviderSettingsCollection Providers
{
get { return (ProviderSettingsCollection)base["providers"]; }
}
///<summary>
/// The name of the default provider
///</summary>
[StringValidator(MinLength = 1)]
[ConfigurationProperty("defaultProvider", DefaultValue = "XmlBlogProvider")]
public string DefaultProvider
{
get { return (string)base["defaultProvider"]; }
set { base["defaultProvider"] = value; }
}
}
上面的示例给出了实现定制段所需的最少代码。在建立简单定制提供程序的其他部分之前,需要注意两个事项:第一,注意类继承了ConfigurationSection。ConfigurationSection类是.NET 2.0中新增的,以前这是通过实现IConfigurationSectionHandler接口来完成的,而该接口已在.NET 2.0中废弃。
定制段处理程序现在可以以编程或声明实现方式来执行。上面的示例使用了声明方式,让框架(以及指定的特性)完成许多工作。例如,在建立ConfigurationProperty特性,指定名称如defaultProvider时,实现方式会把配置文件中的defaultProvider数据绑定到类属性上,且无需编写代码。第二,还要注意使用特性指定验证器的功能。这也有助于减少定制代码的数量,但仍具备以健全的方式进行验证的功能。