欧美三区_成人在线免费观看视频_欧美极品少妇xxxxⅹ免费视频_a级毛片免费播放_鲁一鲁中文字幕久久_亚洲一级特黄

Wince自定義的ConfigurationManager

系統 2243 0

最近在做的WINCE程序即將送測,客戶端有很多東西都要移到配置文件中,于是慣性思維的我們想到了 System.Configuration.ConfigurationManager類。 一如既往的,我們添加個XML文件,重命名為 APP.CONFIG, 修改其中內容為

      <?xml version=
      
        "
      
      
        1.0
      
      
        "
      
       encoding=
      
        "
      
      
        utf-8
      
      
        "
      
       ?>
      
<configuration>


<appSettings>

<!--DeviceSvc地址-->
<add key = " DeviceSvcAddress " value= " http://***********/DeviceSvc.svc " />
</appSettings>

</configuration>

保存之后,在調用的地方很順其自然的 調用

      
        var
      
       filePath = ConfigurationManager.AppSettings[
      
        "DeviceSvcAddress"
      
      ];
    

之后傻眼了,發現CompactFramework這個精簡的.NET框架不支持ConfigurationManager,那怎么辦,這種配置型的字符串不可能放在代碼中啊。轉念一想,其實ConfigurationManager無非也就是個XML文件讀取類,CompactFramework對XML讀寫可是完全支持,那么為何我們不可以自己寫一個。

動手之前可以先整理下需求,這個類要干什么:

1.最好是靜態的,方便調用。

2.能讀取APP。Config中的配置節點。

3.如果再能添加修改就更好了。

?

OK,需求確定那就動手

      
        public
      
      
        static
      
      
        class
      
       AppConfiger
      
{
public static string _configName = string .Empty;
private static XDocument _configDoc = null ;
private static string _path = string .Empty;

static AppConfiger()
{
// 編譯CAB文件發布時要修改為
// _configName = "Cp.Device.exe.Config";

// 正常調試時使用
// #if DEBUG
// _configName = "App.Config";
// #endif
// #if !DEBUG
// _configName = "Cp.Device.exe.Config";
// #endif

LoadConfigurationFile(_configName);
}

??????? private static void LoadConfigurationFile(string configName)
??????? {
??????????? _configDoc = new XDocument();
??????????? string appDir = Path.GetDirectoryName(Assembly.GetExecutingAssembly().GetName().CodeBase);
??????????? _path = Path.Combine(appDir, configName);
??????????? _configDoc = XDocument.Load(_path);

??????? }


}

這是這個類的一個屬性跟構造函數,_configName 這個就是配置文件的文件名,大家注意這一段

      
        //
      
      
        編譯CAB文件發布時要修改為
        
// _configName = "Cp.Device.exe.Config";

// 正常調試時使用
// #if DEBUG
// _configName = "App.Config";
// #endif
// #if !DEBUG
// _configName = "Cp.Device.exe.Config";
// #endif

這一段弄得我好糾結,WINCE程序Deploye運行方式有2種,

  一種是直連開發機,用VS的F5運行之后VS可以做一次發布,你可以修改程序的發布路徑,這種方式中還有DEBUG跟RELEASE模式。由于某種我不知道的原因,這樣的方式發布出來的文件,沒有*.exe.config這樣的配置文件生成,于是我把APP.CONFING屬性改為Contant+copy always。之后就用app.config文件去讀配置。
  另外一種方式就是編譯CAB包安裝,這也是模擬正常發布的流程,這種方式下會生成*.exe.config這個文件,我以為這個模式也會有DEBUG跟RELEASE之分所以就用了 “#if DEBUG” 這樣的編譯路徑去區分,結果發現無論什么方式編譯出來的CAB包,都只會走到 _configName = "App.Config"; 這個分支中,在程序發布時,如果有2個配置文件這種事情也太不專業了

,于是我就換了另外一種思路去讀取配置文件

      
        private
      
      
        static
      
      
        void
      
       LoadConfigurationFile()
      
{

var configName = " App.Config " ;
_configDoc = new XDocument();
string appDir = Path.GetDirectoryName(Assembly.GetExecutingAssembly().GetName().CodeBase);
_path = Path.Combine(appDir, configName);
try
{
_configDoc = XDocument.Load(_path);

}
catch (FileNotFoundException)
{
configName = " Cp.Device.exe.Config " ;
_path = Path.Combine(appDir, configName);
_configDoc = XDocument.Load(_path);
}
catch (Exception)
{
MessageBox.Show( " 配置文件錯誤 " );
return ;
}

}

這樣就會在發布跟編譯時都可以讀取各自的CONFIG文件而不用每次都跑去修改_configName了。

既然我們已經拿到了_configDoc,其他就好說了:

對節點的一些操作

      
        private
      
      
        static
      
       XElement GetDescendant(
      
        string
      
       key)
      
{

var getAppSettings = _configDoc.Descendants( " appSettings " ).Elements();
XElement elem = null ;
foreach ( var setting in getAppSettings)
{
XAttribute keyAtt = setting.Attribute( " key " );
if (keyAtt.Value == key)
{
elem = setting;
break ;
}

}

return elem;

}

public static void Add( string key, string Value)
{
LoadConfigurationFile();
// LoadConfigurationFile(_configName);
XElement element = new XElement( " add " , new XAttribute( " key " , key), new XAttribute( " value " , Value));
var addElement = _configDoc.Descendants( " appSettings " ).Elements().Last();
addElement.AddAfterSelf(element);
_configDoc.Save(_path);

}

public static string GetAppSettingValue( string key)
{
XElement getAppSettings = GetDescendant(key);
var configValue = getAppSettings.Attribute( " value " ).Value;
return configValue.ToString();

}


public static void SetAppSettingValue( string key, string newValue)
{
XElement getAppSettings = GetDescendant(key);
getAppSettings.SetAttributeValue( " value " , newValue);
_configDoc.Save(_path);
}

調用的時候也很簡單

      var i = AppConfiger.GetAppSettingValue("DeviceSvcAddress");


    

?至此,我們自己寫的可以用在CompactFramework中的Confier已經完成了。






Wince自定義的ConfigurationManager


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 亚洲一二三区在线观看 | 亚洲午夜无码毛片AV久久 | 日韩午夜伦y4480私人影院 | 久久精品国产免费观看99 | 色天天综合色天天碰 | 嫩草视频在线播放 | 国产成人免费永久播放视频平台 | 欧美3级| 大香伊蕉国产短视频69 | 素人视频在线观看免费 | 99久久自偷自偷国产精品不卡 | 91精品电影 | 欧美日韩亚洲在线 | 国产日韩欧美一区二区 | 日韩精品 电影一区 亚洲 | 国产污网站在线观看 | 日韩精品久久久久久久电影99爱 | 国产精品v欧美精品∨日韩 一级免费黄色免费片 | 日日摸夜夜添夜夜添精品视频 | 亚洲天堂视频在线观看 | 日本高清视频wwww色 | 日本久草视频 | 九九视频只有精品六 | 亚洲日韩成人 | 国产不卡在线观看视频 | 日韩一二区 | 99久久人妻无码精品系列性欧美 | a级毛片在线免费观看 | 视频一区二区久久 | 免费一级片 | 日韩欧美一区二区三区四区 | 2021国产成人午夜精品 | 欧美激情刺激爽免费视频观看 | 国产一区二区欧美丝袜 | 91色在线| 污污小视频在线观看 | 日本高清天码一区在线播放 | 午夜影视 | 日本aⅴ在线 | 日本一区二区三区免费观看 | 99国产精品2018视频全部 |