在作應(yīng)用系統(tǒng)開(kāi)發(fā)時(shí),管理配置是必不可少的。例如數(shù)據(jù)庫(kù)服務(wù)器的配置、安裝和更新配置等等。由于Xml的興起,現(xiàn)在的配置文件大都是以xml文檔來(lái)存儲(chǔ)。比如Visual Studio.NET自身的配置文件Mashine.config,ASP.NET的配置文件Web.Config,包括我在介紹Remoting中提到的配置文件,都是xml的格式。
傳統(tǒng)的配置文件ini已有被xml文件逐步代替的趨勢(shì),但對(duì)于簡(jiǎn)單的配置,ini文件還是有用武之地的。ini文件其實(shí)就是一個(gè)文本文件,它有固定的格式,節(jié)Section的名字用[]括起來(lái),然后換行說(shuō)明key的值:
[section]
key=value
如數(shù)據(jù)庫(kù)服務(wù)器配置文件:
DBServer.ini
[Server]
Name=localhost
[DB]
Name=NorthWind
[User]
Name=sa
在C#中,對(duì)配置文件的讀寫是通過(guò)API函數(shù)來(lái)完成的,代碼很簡(jiǎn)單:
using System;
using System.Text;
using System.IO;
using System.Runtime.InteropServices;

namespace PubOp


{
public class OperateIniFile

{

API函數(shù)聲明#region API函數(shù)聲明

[DllImport("kernel32")]//返回0表示失敗,非0為成功
private static extern long WritePrivateProfileString(string section,string key,
string val,string filePath);

[DllImport("kernel32")]//返回取得字符串緩沖區(qū)的長(zhǎng)度
private static extern long GetPrivateProfileString(string section,string key,
string def,StringBuilder retVal,int size,string filePath);


#endregion


讀Ini文件#region 讀Ini文件

public static string ReadIniData(string Section,string Key,string NoText,string iniFilePath)

{
if(File.Exists(iniFilePath))

{
StringBuilder temp = new StringBuilder(1024);
GetPrivateProfileString(Section,Key,NoText,temp,1024,iniFilePath);
return temp.ToString();
}
else

{
return String.Empty;
}
}

#endregion


寫Ini文件#region 寫Ini文件

public static bool WriteIniData(string Section,string Key,string Value,string iniFilePath)

{
if(File.Exists(iniFilePath))

{
long OpStation = WritePrivateProfileString(Section,Key,Value,iniFilePath);
if(OpStation == 0)

{
return false;
}
else

{
return true;
}
}
else

{
return false;
}
}

#endregion
}
}
NET技術(shù):C#中讀寫INI配置文件,轉(zhuǎn)載需保留來(lái)源!
鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。