) Config configuration file operations

Source: Internet
Author: User

1. Create a configuration section class

You must create an object inherited from ConfigurationSection to perform configuration data read/write operations,
ConfigurationSection provides an indexer for obtaining and setting configuration data. You must note that attributes with the ConfigurationProperty feature are available.
In the following code, all "IDS" must be the same.

Class ConfigSectionData: ConfigurationSection

{

[ConfigurationProperty ("id")]

Public int Id

{

Get {return (int) this ["id"];}

Set {this ["id"] = value ;}

}

[ConfigurationProperty ("time")]

Public DateTime Time

{

Get {return (DateTime) this ["time"];}

Set {this ["time"] = value ;}

}

}

2. Create a configuration file operation object

Configuration config = ConfigurationManager. OpenExeConfiguration (ConfigurationUserLevel. None );

ConfigSectionData data = new ConfigSectionData ();

Data. Id = 1000;

Data. Time = DateTime. Now;

Config. Sections. Add ("add", data );

Config. Save (ConfigurationSaveMode. Minimal );

The above example is to operate app. config and write configuration data named "add" under the root node (configuration.

<? Xml version = "1.0" encoding = "UTF-8"?>

<Configuration>

<ConfigSections>

<Section name = "add" type = "leleapplication1.configsectiondata,.../>

</ConfigSections>

<Add id = "1000" time = "02/18/2006 21:51:06"/>

</Configuration>

Note that VS2005 writes information to * .vshost.exe in IDE mode. and overwrite the file when the program is closed. Therefore, you may not be able to see the configuration data you have written, as long as you execute * in resource management *. in *. exe. the result is displayed in the config file.

To operate non-default configuration files, you can use the ExeConfigurationFileMap object.

ExeConfigurationFileMap file = new ExeConfigurationFileMap ();

File. ExeConfigFilename = "test. config ";

Configuration config = ConfigurationManager. OpenMappedExeConfiguration (file, ConfigurationUserLevel. None );

ConfigSectionData data = new ConfigSectionData ();

Data. Id = 1000;

Data. Time = DateTime. Now;

Config. Sections. Add ("add", data );

Config. Save (ConfigurationSaveMode. Minimal );

If you do not want to write configuration data under the root node, you can use the ConfigurationSectionGroup object.

ExeConfigurationFileMap file = new ExeConfigurationFileMap ();

File. ExeConfigFilename = "test. config ";

Configuration config = ConfigurationManager. OpenMappedExeConfiguration (file, ConfigurationUserLevel. None );

ConfigSectionData data = new ConfigSectionData ();

Data. Id = 1000;

Data. Time = DateTime. Now;

Config. SectionGroups. Add ("group1", new ConfigurationSectionGroup ());

Config. SectionGroups ["group1"]. Sections. Add ("add", data );

Config. Save (ConfigurationSaveMode. Minimal );

The following is the generated configuration file.

<? Xml version = "1.0" encoding = "UTF-8"?>

<Configuration>

<ConfigSections>

<SectionGroup name = "group1" type = "System. Configuration. ConfigurationSectionGroup,...>

<Section name = "add" type = "leleapplication1.configsectiondata,.../>

</SectionGroup>

</ConfigSections>

<Group1>

<Add id = "1000" time = "02/18/2006 22:01:02"/>

</Group1>

</Configuration>

3. Read the configuration file

ExeConfigurationFileMap file = new ExeConfigurationFileMap ();

File. ExeConfigFilename = "test. config ";

Configuration config = ConfigurationManager. OpenMappedExeConfiguration (file, ConfigurationUserLevel. None );

ConfigSectionData data = config. SectionGroups ["group1"]. Sections ["add"] as ConfigSectionData;

// ConfigSectionData data = config. Sections ["add"] as ConfigSectionData; // read from the root node

If (data! = Null)

{

Console. WriteLine (data. Id );

Console. WriteLine (data. Time );

}

4. Write the configuration file

Before writing to the ConfigurationSectionGroup and ConfigurationSection, you must determine whether the configuration with the same name already exists. Otherwise, the writing will fail.

In addition, if the Configuration file is modified by another Configuration object, saving fails and an exception is thrown. Singleton mode is recommended.

ExeConfigurationFileMap file = new ExeConfigurationFileMap ();

File. ExeConfigFilename = "test. config ";

Configuration config = ConfigurationManager. OpenMappedExeConfiguration (file, ConfigurationUserLevel. None );

ConfigSectionData data = new ConfigSectionData ();

Data. Id = 2000;

Data. Time = DateTime. Now;

Configurationsectiongroup group1 = config. sectiongroups ["group1"];

If (group1 = NULL)

Config. sectiongroups. Add ("group1", new configurationsectiongroup ());

Configurationsection DATA = group1.sections ["add"] As config;

If (add = NULL)

Config. sectiongroups ["group1"]. Sections. Add ("add", data );

Else

{

Group1.sections. Remove ("add ");

Group1.sections. Add ("add", data );

// Or directly modify the original configuration object, provided that the type conversion is successful.

// Configsectiondata configdata = add as configsectiondata;

// Configdata. ID = data. ID;

// Configdata. Time = data. time;

}

Config. Save (configurationsavemode. Minimal );

5. Delete configuration section

Delete configurationsectiongroup

Config. sectiongroups. Remove ("group1 ");

// Config. sectiongroups. Clear ();

Config. Save (ConfigurationSaveMode. Minimal );

Delete ConfigurationSection

Config. Sections. Remove ("add1 ");

// Config. Sections. Clear ();

If (config. SectionGroups ["group1"]! = Null)

{

Config. SectionGroups ["group1"]. Sections. Remove ("add2 ");

// Config. SectionGroups ["group1"]. Sections. Clear ();

}

Config. Save (ConfigurationSaveMode. Minimal );

6. Miscellaneous

You can use ConfigurationManager. OpenMachineConfiguration () to operate the Machine. config file.

You can also use the WebConfigurationManager class in the System. Web. Configuration namespace to operate ASP. NET Configuration files.

ConfigurationManager also provides convenient operations such as deleettings, ConnectionStrings, and GetSection.

7. Use custom classes

For example, in ConfigSectionData

In addition to simple types, do you have custom classes?

You can use a custom class, but you need to define a converter.

Using System;

Using System. Collections;

Using System. Collections. Generic;

Using System. Configuration;

Using System. Globalization;

Using System. ComponentModel;

// The Custom class to write the configuration file

Class CustomData

{

Public CustomData (string s)

{

This. s = s;

}

Private string s;

Public string S

{

Get {return s ;}

Set {s = value ;}

}

}

// Custom converter (the Demo code ignores the type judgment)

Class CustomConvert: ConfigurationConverterBase

{

Public override bool CanConvertFrom (ITypeDescriptorContext ctx, Type type)

{

Return (type = typeof (string ));

}

Public override object Convertor (ITypeDescriptorContext ctx, CultureInfo ci, object value, Type type)

{

Return (value as CustomData). S;

}

Public override object ConvertFrom (ITypeDescriptorContext ctx, CultureInfo ci, object data)

{

Return new CustomData (string) data );;

}

}

Class ConfigSectionData: ConfigurationSection

{

[ConfigurationProperty ("id")]

Public int Id

{

Get {return (int) this ["id"];}

Set {this ["id"] = value ;}

}

[ConfigurationProperty ("time")]

Public DateTime Time

{

Get {return (DateTime) this ["time"];}

Set {this ["time"] = value ;}

}

[ConfigurationProperty ("custom")]

[TypeConverter (typeof (CustomConvert)] // specifies the converter

Public CustomData Custom

{

Get {return (CustomData) this ["custom"];}

Set {this ["custom"] = value ;}

}

}

Public class Program

{

Static void Main (string [] args)

{

Configuration config = ConfigurationManager. OpenExeConfiguration (ConfigurationUserLevel. None );

ConfigSectionData data = new ConfigSectionData ();

Data. Id = 1000;

Data. Time = DateTime. Now;

Data. Custom = new CustomData ("abcdefg ...");

Config. Sections. Add ("add", data );

Config. Save (ConfigurationSaveMode. Minimal );

// Read Test

ConfigSectionData configData = (ConfigSectionData) config. Sections ["add"];

Console. writeline (configdata. Custom. s );

}

}

Saved configuration file

<? XML version = "1.0" encoding = "UTF-8"?>

<Configuration>

<Configsections>

<Section name = "add" type = "..."/>

</Configsections>

<Add id = "1000" time = "04/17/2006 22:06:58" Custom = "abcdefg..."/>

</Configuration>

Contact Us

The content source of this page is from Internet, which doesn't represent Alibaba Cloud's opinion; products and services mentioned on that page don't have any relationship with Alibaba Cloud. If the content of the page makes you feel confusing, please write us an email, we will handle the problem within 5 days after receiving your email.

If you find any instances of plagiarism from the community, please send an email to: info-contact@alibabacloud.com and provide relevant evidence. A staff member will contact you within 5 working days.

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.