目錄
- 1.簡介
- 1.1什么是應用程式配置資料?
- 1.2問題
- 1.3介紹Nini
- 2.入門
- 2.1一個簡單的例子
- 2.2默認值
- 2.3設定、保存和洗掉鍵
- 2.4添加和洗掉配置
- 2.5鍵值擴展
- 3.高級主題
- 3.1合并
- 3.2價值別名
- 3.3鍵值清單
- 3.4活動
- 4.配置型別
- 4.1 Ini檔案
- 4.2 XML檔案
- 4.3 Windows注冊表配置
- 4.4 .NET組態檔
- 4.5命令列(Argv)配置
- 5.有效使用Nini
- 5.1多個用戶的處理配置
- 5.2在資料庫中存盤配置資料
- 5.3自動創建組態檔
- 5.4以編程方式創建組態檔
- 5.5為您的應用程式選擇正確的組態檔型別
- 附件:獲取Nini
Nini .NET配置庫(http://nini.sourceforge.net/)
VB代碼的注釋我保留了原文注釋,它和C#注釋的內容是一樣的,下載鏈接在文章末尾,
1.簡介
1.1什么是應用程式配置資料?
作為開發人員,您始終需要處理應用程式配置資料,常見的示例是INI 檔案,XML檔案, .NET組態檔(也稱為“ .config”),Windows注冊表和命令列(argv)引數,組態檔的優點是它們加載速度快,不占用大量空間且易于編輯,
1.2問題
嘗試創建組態檔訪問方案不能滿足程式員或最終用戶的需求,為了給出真實的生活場景,我為一個使用Windows注冊表API(應用程式編程介面)配置其原始程式的組織作業,后來,他們開發了自己的ASP配置類,大約在同一時間,另一個小組開發了一個API,該API可從資料庫中獲取資料,然后,當ASP.NET出現時,他們開始使用Web.config,在短短的幾年之內,配置資料源的數量就從一增加到了四個!不用說,獲取配置資料通常成為一項艱巨的任務,以下是可以改進配置管理的三個主要方面:
- API
開發人員使用組態檔格式,以使其應用程式在盡可能短的時間內運行,但是,通常在事河駁加用于訪問此資料的API,從而導致API不夠靈活,在很小的應用程式中,這可能不是問題,但是隨著程式代碼庫的增長,配置資訊通常會遍及整個應用程式代碼, - 最終用戶
組態檔通常不會考慮最終用戶,通常,配置選項是簡潔的編程術語,只有最勇敢的用戶才敢更改它們,這導致開發人員不得不撰寫復雜的組態檔編輯器,或更糟糕的是,它們會完全重新設計其原始API, - 多個配置源
隨著您軟體的成熟,添加更多應用程式配置型別的情況并不少見(例如我之前給您的示例),這通常是由于合并其他專案中的代碼,新的改進格式以及遷移到不同的編程平臺而引起的,這迫使程式員學習多個API,最終結果是代碼不一致,也不適合新程式員,不會替換舊的組態檔,因為程式員及其經理不適應更改成熟的代碼,編輯檔案的用戶可以抵制此更改,因為他們希望不學習新的檔案格式,
1.3介紹Nini
Nini是一個功能強大的 .NET配置 庫,旨在幫助快速構建高度可配置的應用程式,Nini提供了一種解決方案,試圖消除上述問題,它提供了一個大型功能集,可為您提供從概念到成熟產品的每個階段都將使用的功能,這是通過簡單但靈活的API實作的,該API提供了對基礎配置源的抽象,它解決了我上面描述的所有問題,我們將在下面的示例中看到如何完成此操作,
2.入門
2.1一個簡單的例子
為了向您展示Nini如何解決這些問題,讓我們來看一個示例,首先,讓我們看一個示例組態檔,對于本手冊中的大多數示例,我將選擇INI 格式,INI檔案是一種久經考驗的真實組態檔型別,用于諸如MySQL,PHP和Samba之類的著名開源專案 ,實際上,Nini支持多種INI檔案型別,它們非常簡單且易于編輯,因此仍然是非常受歡迎的選擇,Nini包含它自己的INI決議器類(IniDocument),該類 完全用C#撰寫,沒有 Windows API代碼,因此它是跨平臺的,這是此示例的MyApp.ini文本:
; MyApp.ini
[Logging]
File Name = MyApp.log
MessageColumns = 5
MaxFileSize = 40000000000000
以下是一段C#示例代碼,它描述了如何從上述檔案中的INI檔案訪問配置資料:
using Nini.Config;
IConfigSource source = new IniConfigSource("MyApp.ini");
string fileName = source.Configs["Logging"].Get("File Name");
int columns = source.Configs["Logging"].GetInt("MessageColumns");
long fileSize = source.Configs["Logging"].GetLong("MaxFileSize");
這是VB中的示例:
Imports Nini.Config
Dim source As New IniConfigSource("MyApp.ini")
Dim fileName As String = source.Configs("Logging").Get("File Name")
Dim columns As Integer = source.Configs("Logging").GetInt("MessageColumns")
Dim fileSize As Long = source.Configs("Logging").GetLong("MaxFileSize")
好的,那個例子給您帶來了一些麻煩,首先,我們使用Nini.Config將Nini的配置名稱空間包含在虛構的應用程式中,接下來,我們使用IniConfigSource 類加載INI檔案,在Nini中,每種組態檔型別都有其自己的“ Source”類,此類知道如何加載和保存檔案,這些類中的每一個都實作IConfigSource 介面,因此您可以更輕松地抽象地使用多種配置型別,加載檔案后,所有部分(在本例中為[Logging]部分)都將轉換為介面IConfig, 并添加到Source類的集合中,IConfig類提供了非常快速的訪問權限,以檢索,添加或洗掉配置密鑰(例如上述INI檔案中的“檔案名”),IConfig類的方法包括 Get, GetString, GetInt, GetFloat, GetDouble和GetLong 方法,所有以“ Get”為前綴的方法都將多載以提供更多資料,接下來的幾節描述了如何使用這些多載,
2.2默認值
有時,組態檔中不會出現選項,這可能是因為尚未將其添加到專案的主版本中,或者應將其對用戶保密,對于這些情況,Nini提供了多載的方法,這些方法允許程式員定義默認值,
這是C#中的示例:
// 將缺少默認值設定為 "Default result".
string missing = config.Get("Missing Config", "Default result");
// 設定smallNumber為默認值,50
int smallNumber = config.GetInt("Not Present", 50);
這是VB中的相同示例:
' Sets missing to the default value, "Default result".
Dim missing As String = config.Get("Missing Config", "Default result")
' Sets smallNumber to the default value, 50.
Dim smallNumber As Integer = config.GetInt("Not Present", 50)
2.3設定、保存和洗掉鍵
也可以設定新值并將其保存到組態檔中,呼叫Set方法將更改現有值,或者如果不存在則將其添加,這是一個例子:
config.Set("File Name", "MyNewFile.log");
config.Set("MessageColumns", 45);
config.Remove("File Name");
source.Save();
但是,有必要呼叫Save方法來保存檔案,但是,您還可以在IConfigSource上設定AutoSave屬性,并且每次呼叫Set方法時,該屬性都會自動保存檔案,如果要將檔案保存到其他路徑或物件,則IniConfigSource, XmlConfigSource和DotNetConfigSource 類都保存多載的Save方法,這些方法使您可以保存到新路徑或TextWriter:
這是C#中的示例:
using System.IO;
IniConfigSource source = new IniConfigSource("Test.ini");
StringWriter writer = new StringWriter();
source.Save(writer); // 保存到StringWriter(TextWriter)
source.Save("some/new/path.ini"); // 保存到新路徑
這是VB中的示例:
Imports System.IO
Dim source As IniConfigSource = new IniConfigSource("Test.ini")
Dim writer As New StringWriter()
source.Save(writer) ' Save to StringWriter(TextWriter)
source.Save("some/new/path.ini") ' Save to new path
2.4添加和洗掉配置
在特定情況下,您將需要自己添加和洗掉IConfigs,Nini具有完成這兩項操作的簡單方法,這是我創建新配置然后立即將其洗掉的示例,
這是C#中的示例:
IConfig newConfig = source.AddConfig("NewConfig");
source.Configs.Remove(newConfig);
這是VB中的示例:
Dim newConfig As IConfig = source.AddConfig("NewConfig")
source.Configs.Remove(newConfig)
2.5鍵值擴展
在許多情況下,您會發現您的鍵值取決于其他鍵的值,例如,您有一個根路徑配置值,以及使用此路徑的檔案的多個值,例如以下示例:
[File Path]
RootPath = C:\Program Files\My Program
Logging = MyApp.log
WebPage = index.html
如果沒有Nini,則如果要將“ RootPath”的值與“ Logging”和“ WebPage”結合使用,則必須執行難看的字串連接才能獲得“ C:\ Program Files \ My Program \ index.html”,在Nini中,您不需要這樣做:
[File Path]
RootPath = C:\Program Files\My Program
Logging = ${RootPath}\MyApp.log
WebPage = ${RootPath}\index.html
這可以為您自己串聯它們省去很多麻煩,并使您的代碼更整潔,如果要從其他部分獲取值,則可以執行上述操作,但是要在部分名稱后添加一個橫條(“ |”),如下所示:$ {section | key},當您準備執行替換時,請呼叫ExpandKeyValues(注意:以前稱為ReplaceKeyValues)
這是C#中的示例:
IConfigSource source = new IniConfigSource("MyApp.ini");
source.ExpandKeyValues();
這是VB中的示例:
Dim source As New IConfigSource("MyApp.ini")
source.ExpandKeyValues()
呼叫ExpandKeyValues時,它會一次更改組態檔中的所有鍵,這使代碼執行更快,因為它不需要替換每個Get / GetString / GetInt / etc呼叫上的鍵值,但是,這意味著如果要使用保存組態檔,它將用擴展值覆寫以前的值,如果您不希望發生這種情況,則可以使用GetExpanded方法,
; 這會將日志記錄設定為 "C:\Program Files\My Program\MyApp.log"
IConfigSource source = new IniConfigSource("MyApp.ini");
string logging = source.Configs["File Path"].GetExpanded("Logging");
這就是創建第一個Nini配置的應用程式很容易,以下各節將介紹Nini的一些更高級的功能,
3.高級主題
3.1合并
合并是一項非常強大的功能,允許開發人員將來自多個源的配置資料組合到一個物件中,您可以將無數種不同的配置型別組合到一個IConfigSource中!您可以將多個INI,XML和注冊表檔案添加到同一物件中,你覺得很酷嗎?這是一個如何將INI檔案與XML檔案合并的示例,
這是C#中的示例:
IConfigSource mainSource = new IniConfigSource("MyApp.ini");
IConfigSource xmlSource = new XmlConfigSource("MyApp.xml");
mainSource.Merge(xmlSource);
// 現在,您可以從mainSource和xmlSource訪問任何IConfig
string xmlValue = https://www.cnblogs.com/timefiles/p/mainSource.Configs["SomeXmlSection"].Get("AnOption");
這是VB中的示例:
Dim mainSource As New IniConfigSource("MyApp.ini")
Dim xmlSource As New XmlConfigSource("MyApp.xml")
mainSource.Merge(xmlSource)
' Now you can access any IConfig from mainSource and xmlSource
Dim xmlValue As String = mainSource.Configs("SomeXmlSection").Get("AnOption")
當資料在檔案之間合并時,任何同名的IConfig或包含相同密鑰的IConfig都將覆寫之前的檔案,對于具有不同配置需求的客戶端的用戶來說,這非常重要,您可以在一個檔案中創建默認配置設定,并具有特定于客戶端的檔案,如果需要,該檔案將覆寫主檔案的設定,這將節省您大量的作業,它對我有用,
3.2價值別名
許多組態檔的選項對于程式員來說是清楚的,但對非程式員來說卻很混亂,為了使非程式員更容易理解組態檔,一種常見的做法是使鍵和值更像普通的人類對話框那樣讀取,讓我們看一個示例,說明如何使用易于理解的字串值回傳布林值,首先,讓我們從AliasExample INI檔案開始:
; AliasExample.ini
[Web Browser]
Block Popups = ON
Check For Default Browser = Off
Error Level = warn
如您所見,我不是使用每個鍵的值都使用“ 1”或“ true”之類的值,而是使用了“ On”和“ Off”,希望它們可以使用戶更容易理解,您還將注意到,每個值之間的大小寫不完全是大寫或小寫,我這樣做是為了提出觀點,用戶很難記住要在特定鍵值中放置什么值,因此要使它們變得更容易一點也不 要使他們也記住要使用哪種情況!忽略大小寫的問題是您的代碼看起來很丑陋,如以下示例所示:
bool blockPopUps = (config.Get("Block Popups").ToLower() == "on");
讓我們為該檔案定義一些規則,使它們成為規則,我們希望 BlockPopUps部分的 值在值設定為“ On”時回傳布林值true,而在值設定為“ Off”時回傳false值,此外,我希望錯誤級別將整數值設定為“ Warn”時回傳100,而將值設定為“ Error”時回傳200,下面的代碼顯示如何向IConfigSource的Alias屬性添加規則,該屬性定義了我在上一段中剛剛定義的規則,
這是C#中的示例:
IConfigSource source = new IniConfigSource("AliasExample.ini");
// 創建兩個布爾別名,
source.Alias.AddAlias("On", true);
source.Alias.AddAlias("Off", false);
// 設定兩個整數別名,
source.Alias.AddAlias("Error Level", "Warn", 100);
source.Alias.AddAlias("Error Level", "Error", 200);
IConfig config = source.Configs["Web Browser"];
bool blockPopUps = config.GetBoolean("BlockPopUps");
int errorCode = config.GetInt("Error Code", true);
這是VB中的示例:
Dim source As New IniConfigSource("AliasExample.ini")
' Creates two Boolean aliases.
source.Alias.AddAlias("On", True)
source.Alias.AddAlias("Off", False)
' Sets two integer aliases.
source.Alias.AddAlias("Error Level", "Warn", 100)
source.Alias.AddAlias("Error Level", "Error", 200)
Dim config As IConfig = source.Configs("Web Browser")
Dim blockPopUps = config.GetBoolean("BlockPopUps")
int errorCode = config.GetInt("Error Code", True)
對AddAlias的前兩個呼叫 將布林值添加到文本“ On”和“ Off”,此方法的接下來的兩個呼叫將別名文本添加到“錯誤級別”配置中,并將文本分別為“警告”和“錯誤”以及數字值100和200,接下來,我獲取了關鍵資料,GetInt方法已多載,因此,如果引數設定為true,則它將以別名而不是文字整數值加載資料,
3.3鍵值清單
Nini沒有用于回傳資訊串列的專用方法,這是因為 .NET Framework 的String.Split方法已經有了使用小技巧的 方法,這是一個INI檔案,其中服務器串列由豎線(“ |”)分隔符分隔:
[MailServers]
ServerList = "http://mail.yahoo.com/|http://www.hotmail.com/|http://www.mail.com/"
現在,使用Split方法,我們將服務器串列作為字串陣列回傳:
string[] serverList = source.Configs["MailServers"].Get("ServerList").Split('|');
這是VB中的示例:
Dim serverList() As String = source.Configs("MailServers").Get("ServerList").Split('|')
您可以使用Split方法使用任意數量的分度器,要有創造力,只需選擇一個不會用作鍵值的分度符即可,
3.4活動
Nini允許開發人員以非連接方式執行操作,從而使事情變得容易,通常,第一個物件可以只使用IConfig,而不必擔心其他物件如何使用它,但是,有時候知道更改配置資料的時間很有用,Nini添加了許多事件來幫助處理這些情況,
在以下情況下,類需要在保存IConfigSource時通知,
這是一個C#示例:
void SourceLoad()
{
source = new IniConfigSource();
source.Saved += new EventHandler(this.source_Saved);
}
void source_Saved(object sender, EventArgs e)
{
// 在這里執行保存操作
}
這是一個VB示例:
Sub SourceLoad()
{
source = New IniConfigSource()
source.Saved += New EventHandler(Me.source_Saved)
}
Sub source_Saved(sender As object, e As EventArgs) Handles source.Saved
{
' perform save actions here
}
還有更多事件,例如Load,KeySet,KeyRemoved,ConfigAdded和ConfigRemoved,
4.配置型別
4.1 Ini檔案
Nini具有使用100%C#撰寫的內置INI決議器,這意味著,與其他INI決議器不同,它將在任何.NET平臺上運行,而不僅僅是運行Windows的平臺,另外,決議器的撰寫旨在提高靈活性,這就是為什么它支持多種INI檔案型別的原因,當前支持的檔案型別如下:
- Windows style (Win32 API GetPrivateProfileString)
- MySQL style
- Python Style
- Samba style
- Nini standard
區分大小寫
IniConfigSource類具有一個允許值不區分大小寫的屬性,對于使用不區分大小寫的舊Win32 API GetPrivateProfileString函式從系統升級軟體的人們,這可能是理想的,這是一個如何使用它的示例:
; 注意,load方法只是將檔案名傳遞給建構式的替代方法,
IConfigSource source = new IniConfigSource();
source.Load("MyApp.ini");
source.CaseSensitive = false;
4.2 XML檔案
Nini擁有自己的XML組態檔結構,與.NET組態檔格式相比,它提供了更大的靈活性,它的主要優點是您可以擁有多個XML組態檔,并且格式更加簡潔,這是格式的示例,您會發現它非常類似于INI檔案,配置值與先前示例中的INI相同:
<!-- MyApp.xml -->
<Nini>
<Section Name="Logging">
<Key Name="File Name" Value="https://www.cnblogs.com/timefiles/p/MyApp.log" />
<Key Name="MessageColumns" Value="https://www.cnblogs.com/timefiles/p/5" />
<Key Name="MaxFileSize" Value="https://www.cnblogs.com/timefiles/p/40000000000000" />
</Section>
</Nini>
加載檔案非常簡單:
// 加載XML檔案
XmlConfigSource source = new XmlConfigSource("MyApp.xml");
// 檢索值
long maxFileSize = source.Configs["Logging"].GetLong("MaxFileSize");
這是VB中的示例:
' Loads the XML file
Dim source As New XmlConfigSource("MyApp.xml")
' Retrieves a value
Dim maxFileSize As Long = source.Configs("Logging").GetLong("MaxFileSize")
4.3 Windows注冊表配置
如果您使用的是許多Microsoft Windows作業系統之一,則可以從Windows注冊表訪問資料,這是注冊表項的示例鍵路徑:
HKEY_LOCAL_MACHINE\Sofware\MyApp\Logging
"File Name" "MyApp.log" REG_SZ
"MessageColumns" "5" REG_DWORD
"MaxFileSize" "40000000" REG_DWORD
要訪問此代碼,該方法比其他方法要復雜一些,您必須創建到注冊表項的映射,此功能還將使您能夠將許多注冊表項合并到一個IConfigSource中,這是一些訪問它的示例代碼,
這是C#中的示例:
using Microsoft.Win32;
RegistryConfigSource source = new RegistryConfigSource();
// 加載注冊表樹
source.AddMapping(Registry.LocalMachine, "Software\\MyApp\\Logging");
// 檢索值
long maxFileSize = source.Configs["Logging"].GetLong("MaxFileSize");
這是VB中的示例:
Imports Microsoft.Win32
Dim source As New RegistryConfigSource()
' Loads the registry tree
source.AddMapping(Registry.LocalMachine, "Software\\MyApp\\Logging")
' Retrieves a value
Dim maxFileSize As Long = source.Configs("Logging").GetLong("MaxFileSize")
如果您想遞回地檢索指定注冊表項下的所有資料,也可以使用一種方法來完成,
如果要使所有子鍵位于具有統一名稱的鍵下,則可以執行以下操作:
using Microsoft.Win32;
// 加載注冊表樹及其下的所有節點
RegistryConfigSource source = new RegistryConfigSource();
source.AddMapping(Registry.LocalMachine, "Software\\MyApp", RegistryRecurse.Flattened);
string maxFileSize = source.Configs["MyApp"].GetString("SomeConfig");
long maxFileSize = source.Configs["Logging"].GetLong("MaxFileSize");
這是VB中的示例:
Imports Microsoft.Win32
' Loads the registry tree and all nodes beneath it without
Dim source As New RegistryConfigSource()
source.AddMapping(Registry.LocalMachine, "Software\\MyApp", RegistryRecurse.Flattened)
Dim maxFileSize As String = source.Configs("MyApp").GetString("SomeConfig");
Dim maxFileSize As Long = source.Configs("Logging").GetLong("MaxFileSize")
4.4 .NET組態檔
.NET Framework具有使用特定XML格式的自己的組態檔機制 ,您可能在ASP.NET中以web.config 檔案的形式熟悉它們,如果將它們與Windows表單,控制臺應用程式或服務一起使用,則將它們稱為[APP NAME] .exe.config檔案,為了支持仍在其應用程式中使用此組態檔格式的用戶,Nini也支持這些檔案,
<!-- ExampleApp.exe.config -->
<configuration>
<configSections>
<section name="Logging" type="System.Configuration.NameValueSectionHandler" />
</configSections>
<Logging>
<add key="File Name" value="https://www.cnblogs.com/timefiles/p/MyApp.log" />
<add key="MessageColumns" value="https://www.cnblogs.com/timefiles/p/5" />
<add key="MaxFileSize" value="https://www.cnblogs.com/timefiles/p/40000000000000" />
</Logging>
</configuration>
訪問資料與加載INI或XML檔案非常相似:
IConfigSource source = new DotNetConfigSource(DotNetConfigSource.GetFullConfigPath());
string fileName = source.Configs["Logging"].Get("File Name");
int columns = source.Configs["Logging"].GetInt("MessageColumns");
long fileSize = source.Configs["Logging"].GetLong("MaxFileSize");
這是VB中的示例:
Dim source As New DotNetConfigSource(DotNetConfigSource.GetFullConfigPath())
Dim fileName As String = source.Configs("Logging").Get("File Name")
Dim columns As Integer = source.Configs("Logging").GetInt("MessageColumns")
Dim fileSize As Long = source.Configs("Logging").GetLong("MaxFileSize")
4.5命令列(Argv)配置
自從編程開始以來,應用程式就具有接受命令列開關的能力,這些開關只是在應用程式首次啟動時傳遞給應用程式的字串,Windows程式Xcopy具有許多命令列 開關 ,而出色的下載應用程式wget也具有其自己的 開關 ,如果您想更多地了解.NET中命令列引數的作業方式, 請單擊此處(鏈接無效),我們的第一個示例與您迄今為止看到的其他示例非常相似,區別在于 AddSwitch 需要為每個鍵配置呼叫方法,有一個短鍵和一個長鍵可用于獲取配置資料,
這是C#中的示例:
public static int Main(string[] args)
{
ArgvConfigSource source = new ArgvConfigSource(args);
source.AddSwitch("Logging", "file-name", "f");
source.AddSwitch("Logging", "columns", "c");
source.AddSwitch("Logging", "max-file-size", "m");
if(args.Length > 0)
{
string fileName = source.Configs["Logging"].Get("file-name");
int columns = source.Configs["Logging"].GetInt("columns");
long fileSize = source.Configs["Logging"].GetLong("max-file-size");
}
}
這是VB中的示例:
Public Static Function Main(args() As String) As Integer
Dim source As New ArgvConfigSource(args)
source.AddSwitch("Logging", "file-name", "f")
source.AddSwitch("Logging", "columns", "c")
source.AddSwitch("Logging", "max-file-size", "m")
If (args.Length > 0) Then
Dim fileName As String = source.Configs("Logging").Get("file-name")
Dim columns As Integer = source.Configs("Logging").GetInt("columns")
Dim fileSize As Long = source.Configs("Logging").GetLong("max-file-size")
End If
End Function
5.有效使用Nini
5.1多個用戶的處理配置
您可能會注意到,.NET 1.0和1.1的ConfigurationSettings類僅提供檢索配置值的方法,這是因為對于程式員來說,以編程方式更改整個應用程式的配置值通常是一個壞主意,全域配置應用程式的方式由管理員決定,因此,我建議您不要更改應用程式級別設定,
但是,至關重要的是,您必須允許用戶根據自己的個人喜好配置應用程式,Nini允許您創建許多不同的組態檔源,因此只需將組態檔放在正確的目錄中即可,Windows程式的標準是應用程式資料目錄:
C:\Documents and Settings[username]\Local Settings\Application Data[Application Name]\Settings.ini
您可以通過以下路徑以編程方式獲取此路徑:
string folder = Environment.GetFolderPath(Environment.SpecialFolder.ApplicationData);
5.2在資料庫中存盤配置資料
如果您正在運行ASP.NET應用程式,則每個系統中可能會有多個用戶,您可能還需要編輯許多用戶設定,大多數Web應用程式都完全配置有資料庫,因此以下是將Nini與資料庫一起使用的示例,
這是一個帶有SQL Server表的非常簡單的示例,這可以很容易地適應任何其他資料庫,這是資料庫表的結構:
CREATE TABLE UserSettings
(
UserId ID,
Settings TEXT
);
ConfigSettings欄位存盤Nini配置值,現在,您可以像這樣加載Nini配置值:
string userId = GetUserId(); // retrieve the user id somehow
SqlCommand command = new SqlCommand("SELECT Settings FROM UserSettings WHERE ID = "
+ userId, connection);
connection.Open();
SqlDataReader reader = command.ExecuteReader();
if(reader.HasRows) {
reader.Read();
IConfigSource source = new XmlConfigSource(new StringReader(reader.GetString(0)));
}
reader.Close();
connection.Close();
5.3自動創建組態檔
對于任何開發專案而言,能夠自動創建構建都是必不可少的,有幾種工具可以完成此任務,例如批處理(.bat)腳本,但是.NET Framework最受歡迎的選擇可能是 NAnt,您可能會發現自己需要使用構建管理系統來創建組態檔,為了使這些作業更輕松,Nini專案提供了NiniEdit(Nini命令列配置編輯器),使用此應用程式,您可以創建和編輯任何基于檔案的配置資料,NiniEditor包含在Examples目錄中的每個Nini版本中,
讓我們添加一個示例,說明如何在構建中使用NiniEdit,在第一個示例中,假設您的構建是一個批處理檔案,并且您需要以編程方式創建以下INI檔案:
[General]
Debug = false
Logging = On
[Logging]
FilePath = C:\temp\MyApp.log
以下呼叫將自動創建組態檔:
:: Create the new configuration file
niniedit --new --set-type=ini MyApp.ini
niniedit --add=General MyApp.ini
niniedit --add=Logging MyApp.ini
niniedit --config=General --set-key=Debug,false MyApp.ini
niniedit --config=General --set-key=Logging,On MyApp.ini
niniedit --config=Logging --set-key=FilePath,C:\temp\MyApp.log MyApp.ini
如果您在NAnt中執行相同的操作,則可以執行以下操作:
<exec program="niniedit" commandline="-n -s INI MyApp.ini" />
<exec program="niniedit" commandline="-a General MyApp.ini" />
<exec program="niniedit" commandline="-a Logging MyApp.ini" />
<exec program="niniedit" commandline="-c General -k Debug,false MyApp.ini" />
<exec program="niniedit" commandline="-c General -k Logging,On MyApp.ini" />
<exec program="niniedit" commandline="-c Logging -k FilePath,C:\temp\MyApp.log MyApp.ini" />
這里的所有都是它的,NiniEdit具有其他功能,例如列出配置,鍵,鍵值和洗掉鍵的功能,如果沒有其他問題,請以NiniEdit為例,說明如何使用Nini撰寫自己的命令列應用程式,
5.4以編程方式創建組態檔
有時,使用應用程式以編程方式創建組態檔可能會很有用,使用Nini進行此操作非常容易,
假設您要創建在任一示例中創建的相同INI檔案:
[General]
Debug = false
Logging = On
[Logging]
FilePath = C:\temp\MyApp.log
在代碼中創建代碼的方法如下:
IniConfigSource source = new IniConfigSource();
IConfig config = source.AddConfig("General");
config.Set("Debug", "false");
config.Set("Logging", "On");
config = source.AddConfig("Logging");
config.Set("FilePath", "C:\\temp\\MyApp.log");
source.Save("MyApp.ini");
5.5為您的應用程式選擇正確的組態檔型別
Nini的撰寫旨在使所有組態檔型別都成為一流公民,這是因為每種組態檔型別都有其自身的優點和缺點,下面的串列包含一些基本準則:
INI
- 速度-檔案型別的決議速度非常快,因此它的加載和保存速度可能比其他型別更快,
- 可讀性-在配置型別中,這可能對用戶最不可怕,如果您要讓用戶手動更改此組態檔,那么我強烈建議您使用此格式,
- 安裝程式-INI檔案受許多型別的安裝程式支持(Wise,NSIS,僅舉幾例),如果您需要構建來編輯這些檔案,那么絕對可以這樣做,
XML
- 速度-XML決議器要加載很多資訊,因此這可能是最慢的,
- 可讀性-這種格式對于初學者來說有點嚇人,
- 支持-所有編程語言都支持此功能,因此,如果其他應用程式正在訪問資料,那么這是一個很好的型別,
- 安裝程式-由于組態檔沒有標準的XML格式,因此安裝程式通常不支持此格式,
.NET組態檔
- 速度-XML決議器要加載很多資訊,因此這可能是最慢的,
- 可讀性-這種格式對于初學者來說有點嚇人,
- 安裝程式-.NET Framework將這些組態檔用于其他配置,如果將.NET配置和您自己的應用程式配置選項混合使用,我建議不要使用它,
Windows注冊表
- 速度-快速檢索配置資料,隨著注冊表越來越多地填充資料,檢索速度的確會變慢,這被認為是定期重新安裝Windows可以使計算機運行更快的原因之一,
- 可讀性-如果您確實不希望用戶能夠配置應用程式,則應使用此型別,觸摸注冊表可能會導致嚴重問題,因此建議除非必要,否則不要使用它,但是,請注意,如果您的支持人員需要用戶調整配置設定,他們將遇到與用戶相同的問題,除此之外,組態檔編輯器是眾所周知的并且很成熟,
- 安裝程式-大多數安裝程式支持讀取和編輯注冊表項,因此這是一個不錯的選擇,
沒有完美的配置型別,因為每個配置都有自己的優勢,如果最終選擇的組態檔型別不適合您的情況,則不要驚慌,Nini提取了您要訪問的檔案型別,因此您必須更改的代碼量應該最少,
本教程就是這樣,希望對您有所幫助!如果您有任何關于改進本手冊的問題或建議,請訪問Nini主頁,并使用論壇,錯誤跟蹤器或功能請求工具來表達自己的意見,
附件:獲取Nini
- 官網下載串列(推薦)
- Nini-1.1.0網盤鏈接(提取碼:c9vw)
轉載請註明出處,本文鏈接:https://www.uj5u.com/net/98002.html
標籤:C#
下一篇:C# Monitor and transfer or copy the changed or created file to a new location
