详解C#如何读写config配置文件

配置文件概述:

应用程序配置文件是标准的 XML 文件,XML 标记和属性是区分大小写的。它是可以按需要更改的,开发人员可以使用配置文件来更改设置,而不必重编译应用程序。配置文件的根节点是configuration。我们经常访问的是appSettings,它是由.Net预定义的配置节。我们经常使用的配置文件的架构是客诉下面的形式。先大概有个印象,通过后面的实例会有一个比较清楚的认识。下面的“配置节”可以理解为进行配置一个XML的节点。

对于一个config文件:

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
 <appSettings>
 <add key="ServerIP" value="127.0.0.1"></add>
 <add key="DataBase" value="WarehouseDB"></add>
 <add key="user" value="sa"></add>
 <add key="password" value="sa"></add>
 </appSettings>
</configuration> 

对config配置文件的读写类:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Text.RegularExpressions;
using System.Configuration;
using System.ServiceModel;
using System.ServiceModel.Configuration;

namespace NetUtilityLib
{
 public static class ConfigHelper
 {
  //依据连接串名字connectionName返回数据连接字符串
  public static string GetConnectionStringsConfig(string connectionName)
  {
   //指定config文件读取
   string file = System.Windows.Forms.Application.ExecutablePath;
   System.Configuration.Configuration config = ConfigurationManager.OpenExeConfiguration(file);
   string connectionString =
    config.ConnectionStrings.ConnectionStrings[connectionName].ConnectionString.ToString();
   return connectionString;
  }

  ///<summary>
  ///更新连接字符串
  ///</summary>
  ///<param name="newName">连接字符串名称</param>
  ///<param name="newConString">连接字符串内容</param>
  ///<param name="newProviderName">数据提供程序名称</param>
  public static void UpdateConnectionStringsConfig(string newName, string newConString, string newProviderName)
  {
   //指定config文件读取
   string file = System.Windows.Forms.Application.ExecutablePath;
   Configuration config = ConfigurationManager.OpenExeConfiguration(file);

   bool exist = false; //记录该连接串是否已经存在
   //如果要更改的连接串已经存在
   if (config.ConnectionStrings.ConnectionStrings[newName] != null)
   {
    exist = true;
   }
   // 如果连接串已存在,首先删除它
   if (exist)
   {
    config.ConnectionStrings.ConnectionStrings.Remove(newName);
   }
   //新建一个连接字符串实例
   ConnectionStringSettings mySettings =
    new ConnectionStringSettings(newName, newConString, newProviderName);
   // 将新的连接串添加到配置文件中.
   config.ConnectionStrings.ConnectionStrings.Add(mySettings);
   // 保存对配置文件所作的更改
   config.Save(ConfigurationSaveMode.Modified);
   // 强制重新载入配置文件的ConnectionStrings配置节
   ConfigurationManager.RefreshSection("ConnectionStrings");
  }

  ///<summary>
  ///返回*.exe.config文件中appSettings配置节的value项
  ///</summary>
  ///<param name="strKey"></param>
  ///<returns></returns>
  public static string GetAppConfig(string strKey)
  {
   string file = System.Windows.Forms.Application.ExecutablePath;
   Configuration config = ConfigurationManager.OpenExeConfiguration(file);
   foreach (string key in config.AppSettings.Settings.AllKeys)
   {
    if (key == strKey)
    {
     return config.AppSettings.Settings[strKey].Value.ToString();
    }
   }
   return null;
  }

  ///<summary>
  ///在*.exe.config文件中appSettings配置节增加一对键值对
  ///</summary>
  ///<param name="newKey"></param>
  ///<param name="newValue"></param>
  public static void UpdateAppConfig(string newKey, string newValue)
  {
   string file = System.Windows.Forms.Application.ExecutablePath;
   Configuration config = ConfigurationManager.OpenExeConfiguration(file);
   bool exist = false;
   foreach (string key in config.AppSettings.Settings.AllKeys)
   {
    if (key == newKey)
    {
     exist = true;
    }
   }
   if (exist)
   {
    config.AppSettings.Settings.Remove(newKey);
   }
   config.AppSettings.Settings.Add(newKey, newValue);
   config.Save(ConfigurationSaveMode.Modified);
   ConfigurationManager.RefreshSection("appSettings");
  }

  // 修改system.serviceModel下所有服务终结点的IP地址
  public static void UpdateServiceModelConfig(string configPath, string serverIP)
  {
   Configuration config = ConfigurationManager.OpenExeConfiguration(configPath);
   ConfigurationSectionGroup sec = config.SectionGroups["system.serviceModel"];
   ServiceModelSectionGroup serviceModelSectionGroup = sec as ServiceModelSectionGroup;
   ClientSection clientSection = serviceModelSectionGroup.Client;
   foreach (ChannelEndpointElement item in clientSection.Endpoints)
   {
    string pattern = @"\b\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}\b";
    string address = item.Address.ToString();
    string replacement = string.Format("{0}", serverIP);
    address = Regex.Replace(address, pattern, replacement);
    item.Address = new Uri(address);
   }

   config.Save(ConfigurationSaveMode.Modified);
   ConfigurationManager.RefreshSection("system.serviceModel");
  }

  // 修改applicationSettings中App.Properties.Settings中服务的IP地址
  public static void UpdateConfig(string configPath, string serverIP)
  {
   Configuration config = ConfigurationManager.OpenExeConfiguration(configPath);
   ConfigurationSectionGroup sec = config.SectionGroups["applicationSettings"];
   ConfigurationSection configSection = sec.Sections["DataService.Properties.Settings"];
   ClientSettingsSection clientSettingsSection = configSection as ClientSettingsSection;
   if (clientSettingsSection != null)
   {
    SettingElement element1 = clientSettingsSection.Settings.Get("DataService_SystemManagerWS_SystemManagerWS");
    if (element1 != null)
    {
     clientSettingsSection.Settings.Remove(element1);
     string oldValue = element1.Value.ValueXml.InnerXml;
     element1.Value.ValueXml.InnerXml = GetNewIP(oldValue, serverIP);
     clientSettingsSection.Settings.Add(element1);
    }

    SettingElement element2 = clientSettingsSection.Settings.Get("DataService_EquipManagerWS_EquipManagerWS");
    if (element2 != null)
    {
     clientSettingsSection.Settings.Remove(element2);
     string oldValue = element2.Value.ValueXml.InnerXml;
     element2.Value.ValueXml.InnerXml = GetNewIP(oldValue, serverIP);
     clientSettingsSection.Settings.Add(element2);
    }
   }
   config.Save(ConfigurationSaveMode.Modified);
   ConfigurationManager.RefreshSection("applicationSettings");
  }

  private static string GetNewIP(string oldValue, string serverIP)
  {
   string pattern = @"\b\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}\b";
   string replacement = string.Format("{0}", serverIP);
   string newvalue = Regex.Replace(oldValue, pattern, replacement);
   return newvalue;
  }
 }
}

测试代码如下:

 class Program
 {
  static void Main(string[] args)
  {
   try
   {
    //string file = System.Windows.Forms.Application.ExecutablePath + ".config";
    //string file1 = AppDomain.CurrentDomain.SetupInformation.ConfigurationFile;
    string serverIP = ConfigHelper.GetAppConfig("ServerIP");
    string db = ConfigHelper.GetAppConfig("DataBase");
    string user = ConfigHelper.GetAppConfig("user");
    string password = ConfigHelper.GetAppConfig("password");

    Console.WriteLine(serverIP);
    Console.WriteLine(db);
    Console.WriteLine(user);
    Console.WriteLine(password);

    ConfigHelper.UpdateAppConfig("ServerIP", "192.168.1.11");
    string newIP = ConfigHelper.GetAppConfig("ServerIP");
    Console.WriteLine(newIP);

    Console.ReadKey();
   }
   catch (Exception ex)
   {
    Console.WriteLine(ex.Message);
   }
  }
 }

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • C#读写操作app.config中的数据应用介绍

    读语句: 复制代码 代码如下: String str = ConfigurationManager.AppSettings["DemoKey"]; 写语句: 复制代码 代码如下: Configuration cfa = ConfigurationManager.OpenExeConfiguration(ConfigurationUserLevel.None); 2 cfa.AppSettings.Settings["DemoKey"].Value = "D

  • C#读写config配置文件的方法

    如下所示: <?xml version="1.0" encoding="utf-8" ?> <configuration> <appSettings> <add key="ServerIP" value="127.0.0.1"></add> <add key="DataBase" value="WarehouseDB"&g

  • c#读写App.config,ConfigurationManager.AppSettings 不生效的解决方法

    我们经常会希望在程序中写入一些配置信息,例如版本号,以及数据库的连接字符串等.你可能知道在WinForm应用程序中可以利用Properties.Settings来进行类似的工作,但这些其实都利用了App.config配置文件. 本文探讨用代码的方式访问 App.config 的方法.关于 App.config 的使用远比上面提到的用途复杂,因此仅讨论最基本的 appSettings 配置节. 一.配置文件概述: 应用程序配置文件是标准的 XML 文件,XML 标记和属性是区分大小写的.它是可以按

  • 详解C#如何读写config配置文件

    配置文件概述: 应用程序配置文件是标准的 XML 文件,XML 标记和属性是区分大小写的.它是可以按需要更改的,开发人员可以使用配置文件来更改设置,而不必重编译应用程序.配置文件的根节点是configuration.我们经常访问的是appSettings,它是由.Net预定义的配置节.我们经常使用的配置文件的架构是客诉下面的形式.先大概有个印象,通过后面的实例会有一个比较清楚的认识.下面的"配置节"可以理解为进行配置一个XML的节点. 对于一个config文件: <?xml ve

  • 详解Spring-boot中读取config配置文件的两种方式

    了解过spring-Boot这个技术的,应该知道Spring-Boot的核心配置文件application.properties,当然也可以通过注解自定义配置文件的信息. Spring-Boot读取配置文件的方式: 一.读取核心配置文件信息application.properties的内容 核心配置文件是指在resources根目录下的application.properties或application.yml配置文件,读取这两个配置文件的方法有两种,都比较简单. 核心配置文件applicati

  • 详解Python利用configparser对配置文件进行读写操作

    简介 想写一个登录注册的demo,但是以前的demo数据都写在程序里面,每一关掉程序数据就没保存住.. 于是想着写到配置文件里好了 Python自身提供了一个Module - configparser,来进行对配置文件的读写 Configuration file parser. A configuration file consists of sections, lead by a "[section]" header, and followed by "name: valu

  • 详解go基于viper实现配置文件热更新及其源码分析

    go第三方库 github.com/spf13/viper实现了对配置文件的读取并注入到结构中,好用方便. 其中以 viperInstance := viper.New() // viper实例 viperInstance.WatchConfig() viperInstance.OnConfigChange(func(e fsnotify.Event) { log.Print("Config file updated.") viperLoadConf(viperInstance) //

  • 详解Mybatis是如何解析配置文件的

    缘起 经过前面三章的入门,我们大概了解了Mybatis的主线逻辑是什么样子的,在本章中,我们将正式进入Mybatis的源码海洋. Mybatis是如何解析xml的 构建Configuration 我们调用new SqlSessionFactoryBuilder().build()方法的最终目的就是构建 Configuration对象,那么Configuration何许人也?Configuration对象是一个配置管家, Configuration对象之中维护着所有的配置信息. Configura

  • SpringBoot详解如何实现读写分离

    目录 前言 1.项目引入依赖 2.yml配置 3.启动 4.测试 5.中间所遇到的问题 前言 根据公司业务需求,项目需要读写分离,所以记录下读写分离的过程. 分为两个部分: 1.项目的读写分离. 2.mysql数据库的主从复制. 本篇使用的依赖包为sharding-jdbc-spring-boot-starter,也有考虑直接用dynamic-datasource-spring-boot-starter,但是需要在程序中显式的声明所指定的数据源,并且在从库>=2 的时候需要自己写算法进行读库的选

  • 详解如何利用jasypt实现配置文件加密

    目录 引入依赖 生效 作用域 应用 工具类 配置 属性一览 进阶 Jasypt (Java Simplified Encryption) 是一个 java 库,它允许开发人员以最小的成本将基本的加密功能添加到项目中,而无需深入了解密码学的工作原理. 引入依赖 <dependency> <groupId>com.github.ulisesbocchio</groupId> <artifactId>jasypt-spring-boot-starter</a

  • 详解spring boot starter redis配置文件

    spring-boot-starter-Redis主要是通过配置RedisConnectionFactory中的相关参数去实现连接redis service. RedisConnectionFactory是一个接口,有如下4个具体的实现类,我们通常使用的是JedisConnectionFactory. 在spring boot的配置文件中redis的基本配置如下: # Redis服务器地址 spring.redis.host=192.168.0.58 # Redis服务器连接端口 spring.

  • 详解Flutter如何读写文本文件

    目录 介绍 示例 1:加载内容 预览 完整代码 示例 2: Reading and Writing 获取文件路径 示例预览 完整的代码和解释 介绍 文本文件(具有 .txt扩展名)广泛用于持久存储信息,从数字数据到长文本.今天,我将介绍 2 个使用此文件类型的 Flutter 应用程序示例. 第一个示例快速而简单.它仅使用 rootBundle(来自 services.dart)从 assets 文件夹(或根项目中的另一个文件夹)中的文本加载内容,然后将结果输出到屏幕上.当您只需要读取数据而不需

随机推荐