在作应用系统开发时,管理配置是必不可少的。例如数据库服务器的配置、安装和更新配置等等。由于Xml的兴起,现在的配置文件大都是以xml文档来存储。比如Visual Studio.Net自身的配置文件Mashine.config,Asp.Net的配置文件Web.Config,包括我在介绍Remoting中提到的配置文件,都是xml的格式。
传统的配置文件ini已有被xml文件逐步代替的趋势,但对于简单的配置,ini文件还是有用武之地的。ini文件其实就是一个文本文件,它有固定的格式,节Section的名字用[]括起来,然后换行说明key的值:
[section] key=value
如数据库服务器配置文件:
DBServer.ini[Server]Name=localhost[DB]Name=NorthWind[User]Name=sa
在C#中,对配置文件的读写是通过API函数来完成的,代码很简单:
usingSystem;usingSystem.Text;usingSystem.IO;usingSystem.Runtime.InteropServices;namespacePubOp{publicclassOperateIniFile{API函数声明#regionAPI函数声明[DllImport("kernel32")]//返回0表示失败,非0为成功privatestaticexternlongWritePrivateProfileString(stringsection,stringkey,stringval,stringfilePath);[DllImport("kernel32")]//返回取得字符串缓冲区的长度privatestaticexternlongGetPrivateProfileString(stringsection,stringkey,stringdef,StringBuilderretVal,intsize,stringfilePath);#endregion读Ini文件#region读Ini文件publicstaticstringReadIniData(stringSection,stringKey,stringNoText,stringiniFilePath){if(File.Exists(iniFilePath)){StringBuildertemp=newStringBuilder(1024);GetPrivateProfileString(Section,Key,NoText,temp,1024,iniFilePath);returntemp.ToString();}else{returnString.Empty;}}#endregion写Ini文件#region写Ini文件publicstaticboolWriteIniData(stringSection,stringKey,stringValue,stringiniFilePath){if(File.Exists(iniFilePath)){longOpStation=WritePrivateProfileString(Section,Key,Value,iniFilePath);if(OpStation==0){returnfalse;}else{returntrue;}}else{returnfalse;}}#endregion}}简单说明以下方法WriteIniData()和ReadIniData()的参数。
Section参数、Key参数和IniFilePath不用再说,Value参数表明key的值,而这里的NoText对应API函数的def参数,它的值由用户指定,是当在配置文件中没有找到具体的Value时,就用NoText的值来代替。
本文源自:翔宇亭——IT乐园(http://),转载请保留此信息!