主頁 > .NET開發 > .NET開源類別庫Nini手冊(INI、XML、注冊表的配置應用)-中文翻譯

.NET開源類別庫Nini手冊(INI、XML、注冊表的配置應用)-中文翻譯

2020-09-21 15:43:22 .NET開發

目錄
  • 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# 中的 char 、 string(一)

下一篇:C# Monitor and transfer or copy the changed or created file to a new location

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • WebAPI簡介

    Web體系結構: 有三個核心:資源(resource),URL(統一資源識別符號)和表示 他們的關系是這樣的:一個資源由一個URL進行標識,HTTP客戶端使用URL定位資源,表示是從資源回傳資料,媒體型別是資源回傳的資料格式。 接下來我們說下HTTP. HTTP協議的系統是一種無狀態的方式,使用請求/ ......

    uj5u.com 2020-09-09 22:07:47 more
  • asp.net core 3.1 入口:Program.cs中的Main函式

    本文分析Program.cs 中Main()函式中代碼的運行順序分析asp.net core程式的啟動,重點不是剖析原始碼,而是理清程式開始時執行的順序。到呼叫了哪些實體,哪些法方。asp.net core 3.1 的程式入口在專案Program.cs檔案里,如下。ususing System; us ......

    uj5u.com 2020-09-09 22:07:49 more
  • asp.net網站作為websocket服務端的應用該如何寫

    最近被websocket的一個問題困擾了很久,有一個需求是在web網站中搭建websocket服務。客戶端通過網頁與服務器建立連接,然后服務器根據ip給客戶端網頁發送資訊。 其實,這個需求并不難,只是剛開始對websocket的內容不太了解。上網搜索了一下,有通過asp.net core 實作的、有 ......

    uj5u.com 2020-09-09 22:08:02 more
  • ASP.NET 開源匯入匯出庫Magicodes.IE Docker中使用

    Magicodes.IE在Docker中使用 更新歷史 2019.02.13 【Nuget】版本更新到2.0.2 【匯入】修復單列匯入的Bug,單元測驗“OneColumnImporter_Test”。問題見(https://github.com/dotnetcore/Magicodes.IE/is ......

    uj5u.com 2020-09-09 22:08:05 more
  • 在webform中使用ajax

    如果你用過Asp.net webform, 說明你也算是.NET 開發的老兵了。WEBform應該是2011 2013左右,當時還用visual studio 2005、 visual studio 2008。后來基本都用的是MVC。 如果是新開發的專案,估計沒人會用webform技術。但是有些舊版 ......

    uj5u.com 2020-09-09 22:08:50 more
  • iis添加asp.net網站,訪問提示:由于擴展配置問題而無法提供您請求的

    今天在iis服務器配置asp.net網站,遇到一個問題,記錄一下: 問題:由于擴展配置問題而無法提供您請求的頁面。如果該頁面是腳本,請添加處理程式。如果應下載檔案,請添加 MIME 映射。 WindowServer2012服務器,添加角色安裝完.netframework和iis之后,運行aspx頁面 ......

    uj5u.com 2020-09-09 22:10:00 more
  • WebAPI-處理架構

    帶著問題去思考,大家好! 問題1:HTTP請求和回傳相應的HTTP回應資訊之間發生了什么? 1:首先是最底層,托管層,位于WebAPI和底層HTTP堆疊之間 2:其次是 訊息處理程式管道層,這里比如日志和快取。OWIN的參考是將訊息處理程式管道的一些功能下移到堆疊下端的OWIN中間件了。 3:控制器處理 ......

    uj5u.com 2020-09-09 22:11:13 more
  • 微信門戶開發框架-使用指導說明書

    微信門戶應用管理系統,采用基于 MVC + Bootstrap + Ajax + Enterprise Library的技術路線,界面層采用Boostrap + Metronic組合的前端框架,資料訪問層支持Oracle、SQLServer、MySQL、PostgreSQL等資料庫。框架以MVC5,... ......

    uj5u.com 2020-09-09 22:15:18 more
  • WebAPI-HTTP編程模型

    帶著問題去思考,大家好!它是什么?它包含什么?它能干什么? 訊息 HTTP編程模型的核心就是訊息抽象,表示為:HttPRequestMessage,HttpResponseMessage.用于客戶端和服務端之間交換請求和回應訊息。 HttpMethod類包含了一組靜態屬性: private stat ......

    uj5u.com 2020-09-09 22:15:23 more
  • 部署WebApi隨筆

    一、跨域 NuGet參考Microsoft.AspNet.WebApi.Cors WebApiConfig.cs中配置: // Web API 配置和服務 config.EnableCors(new EnableCorsAttribute("*", "*", "*")); 二、清除默認回傳XML格式 ......

    uj5u.com 2020-09-09 22:15:48 more
最新发布
  • C#多執行緒學習(二) 如何操縱一個執行緒

    <a href="https://www.cnblogs.com/x-zhi/" target="_blank"><img width="48" height="48" class="pfs" src="https://pic.cnblogs.com/face/2943582/20220801082530.png" alt="" /></...

    uj5u.com 2023-04-19 09:17:20 more
  • C#多執行緒學習(二) 如何操縱一個執行緒

    C#多執行緒學習(二) 如何操縱一個執行緒 執行緒學習第一篇:C#多執行緒學習(一) 多執行緒的相關概念 下面我們就動手來創建一個執行緒,使用Thread類創建執行緒時,只需提供執行緒入口即可。(執行緒入口使程式知道該讓這個執行緒干什么事) 在C#中,執行緒入口是通過ThreadStart代理(delegate)來提供的 ......

    uj5u.com 2023-04-19 09:16:49 more
  • 記一次 .NET某醫療器械清洗系統 卡死分析

    <a href="https://www.cnblogs.com/huangxincheng/" target="_blank"><img width="48" height="48" class="pfs" src="https://pic.cnblogs.com/face/214741/20200614104537.png" alt="" /&g...

    uj5u.com 2023-04-18 08:39:04 more
  • 記一次 .NET某醫療器械清洗系統 卡死分析

    一:背景 1. 講故事 前段時間協助訓練營里的一位朋友分析了一個程式卡死的問題,回過頭來看這個案例比較經典,這篇稍微整理一下供后來者少踩坑吧。 二:WinDbg 分析 1. 為什么會卡死 因為是表單程式,理所當然就是看主執行緒此時正在做什么? 可以用 ~0s ; k 看一下便知。 0:000> k # ......

    uj5u.com 2023-04-18 08:33:10 more
  • SignalR, No Connection with that ID,IIS

    <a href="https://www.cnblogs.com/smartstar/" target="_blank"><img width="48" height="48" class="pfs" src="https://pic.cnblogs.com/face/u36196.jpg" alt="" /></a>...

    uj5u.com 2023-03-30 17:21:52 more
  • 一次對pool的誤用導致的.net頻繁gc的診斷分析

    <a href="https://www.cnblogs.com/dotnet-diagnostic/" target="_blank"><img width="48" height="48" class="pfs" src="https://pic.cnblogs.com/face/3115652/20230225090434.png" alt=""...

    uj5u.com 2023-03-28 10:15:33 more
  • 一次對pool的誤用導致的.net頻繁gc的診斷分析

    <a href="https://www.cnblogs.com/dotnet-diagnostic/" target="_blank"><img width="48" height="48" class="pfs" src="https://pic.cnblogs.com/face/3115652/20230225090434.png" alt=""...

    uj5u.com 2023-03-28 10:13:31 more
  • C#遍歷指定檔案夾中所有檔案的3種方法

    <a href="https://www.cnblogs.com/xbhp/" target="_blank"><img width="48" height="48" class="pfs" src="https://pic.cnblogs.com/face/957602/20230310105611.png" alt="" /></a&...

    uj5u.com 2023-03-27 14:46:55 more
  • C#/VB.NET:如何將PDF轉為PDF/A

    <a href="https://www.cnblogs.com/Carina-baby/" target="_blank"><img width="48" height="48" class="pfs" src="https://pic.cnblogs.com/face/2859233/20220427162558.png" alt="" />...

    uj5u.com 2023-03-27 14:46:35 more
  • 武裝你的WEBAPI-OData聚合查詢

    <a href="https://www.cnblogs.com/podolski/" target="_blank"><img width="48" height="48" class="pfs" src="https://pic.cnblogs.com/face/616093/20140323000327.png" alt="" /><...

    uj5u.com 2023-03-27 14:46:16 more