技术开发 频道

.net中读写config文件:配置文件操作

        【IT168 技术】今天谈谈在.net中读写config文件的各种方法。 我将介绍各种配置文件的读写操作。 由于内容较为直观,因此没有过多的空道理,只有实实在在的演示代码, 目的只为了再现实战开发中的各种场景。希望大家能喜欢。

  通常,我们在.NET开发过程中,会接触二种类型的配置文件:config文件,xml文件。 今天的博客示例也将介绍这二大类的配置文件的各类操作。 在config文件中,我将主要演示如何创建自己的自定义的配置节点,而不是介绍如何使用appSetting 。

  请明:本文所说的config文件特指app.config或者web.config,而不是一般的XML文件。 在这类配置文件中,由于.net framework已经为它们定义了一些配置节点,因此我们并不能简单地通过序列化的方式去读写它。

  config文件 - 自定义配置节点

  为什么要自定义的配置节点?

  确实,有很多人在使用config文件都是直接使用appSetting的,把所有的配置参数全都塞到那里,这样做虽然不错, 但是如果参数过多,这种做法的缺点也会明显地暴露出来:appSetting中的配置参数项只能按key名来访问,不能支持复杂的层次节点也不支持强类型, 而且由于全都只使用这一个集合,你会发现:完全不相干的参数也要放在一起!

  想摆脱这种困扰吗?自定义的配置节点将是解决这个问题的一种可行方法。

  首先,我们来看一下如何在app.config或者web.config中增加一个自定义的配置节点。 在这篇博客中,我将介绍4种自定义配置节点的方式,最终的配置文件如下:

create procedure ChangeProductQuantity(

  @ProductID
int,

  @Quantity
int

  )

  
as

  update Products
set Quantity = @Quantity

  where ProductID
= @ProductID;

  ]]
>


  create procedure DeleteCategory(

  @CategoryID
int

  )

  
as

  delete from Categories

  where CategoryID
= @CategoryID;

  ]]
>

  同时,我还提供所有的示例代码(文章结尾处可供下载),演示程序的界面如下:

  config文件 - Property

  先来看最简单的自定义节点,每个配置值以属性方式存在:

<MySection111 username="fish-li" url="http://www.cnblogs.com/fish-li/"></MySection111>

  实现代码如下:

 public class MySection1 : ConfigurationSection

  {

  [ConfigurationProperty(
"username", IsRequired = true)]

  
public string UserName

  {

  
get { return this["username"].ToString(); }

  
set { this["username"] = value; }

  }

  [ConfigurationProperty(
"url", IsRequired = true)]

  
public string Url

  {

  
get { return this["url"].ToString(); }

  
set { this["url"] = value; }

  }

  }

  小结:

  1. 自定义一个类,以ConfigurationSection为基类,各个属性要加上[ConfigurationProperty] ,ConfigurationProperty的构造函数中传入的name字符串将会用于config文件中,表示各参数的属性名称。

  2. 属性的值的读写要调用this[],由基类去保存,请不要自行设计Field来保存。

  3. 为了能使用配置节点能被解析,需要在中注册:

,且要注意name="MySection111"要与是对应的。

  说明:下面将要介绍另三种配置节点,虽然复杂一点,但是一些基础的东西与这个节点是一样的,所以后面我就不再重复说明了。

  config文件 - Element

  再来看个复杂点的,每个配置项以XML元素的方式存在:

<MySection222>
    
<users username="fish" password="liqifeng"></users>
</MySection222>

 

  实现代码如下:

public class MySection2 : ConfigurationSection
{
    [ConfigurationProperty(
"users", IsRequired = true)]
    
public MySectionElement Users
    {
        
get { return (MySectionElement)this["users"]; }
    }
}

public class MySectionElement : ConfigurationElement
{
    [ConfigurationProperty(
"username", IsRequired = true)]
    
public string UserName
    {
        
get { return this["username"].ToString(); }
        
set { this["username"] = value; }
    }

    [ConfigurationProperty(
"password", IsRequired = true)]
    
public string Password
    {
        
get { return this["password"].ToString(); }
        
set { this["password"] = value; }
    }
}

  小结:

  1. 自定义一个类,以ConfigurationSection为基类,各个属性除了要加上[ConfigurationProperty]

  2. 类型也是自定义的,具体的配置属性写在ConfigurationElement的继承类中。

  config文件 - CDATA

  有时配置参数包含较长的文本,比如:一段SQL脚本,或者一段HTML代码,那么,就需要CDATA节点了。假设要实现一个配置,包含二段SQL脚本:

<MySection333>
    
<Command1>
        
<![CDATA[
            create procedure ChangeProductQuantity(
                @ProductID
int,
                @Quantity
int
            )
            
as
            update Products
set Quantity = @Quantity
            where ProductID
= @ProductID;
        ]]
>
    
</Command1>
    
<Command2>
        
<![CDATA[
            create procedure DeleteCategory(
                @CategoryID
int
            )
            
as
            delete from Categories
            where CategoryID
= @CategoryID;
        ]]
>
    
</Command2>
</MySection333>

  

0
相关文章