c#读取Config文件的问题

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了c#读取Config文件的问题相关的知识,希望对你有一定的参考价值。

public class IBatisHelper

private static ISqlMapper mapper;

public static bool ibatisInit(String sqlmapPath)

try

DomSqlMapBuilder builder = new DomSqlMapBuilder();
mapper = builder.Configure(sqlmapPath) as SqlMapper;
return true;

catch (Exception ex)

ExceptionUtil.printException(ex);

return false;



每次运行到 mapper = builder.Configure(sqlmapPath) as SqlMapper;就会报如下异常,
----异常消息----------------------------

- The error occurred while loading Providers.
在 IBatisNet.DataMapper.Configuration.DomSqlMapBuilder.Build(XmlDocument document, DataSource dataSource, Boolean useConfigFileWatcher, Boolean isCallFromDao)
在 IBatisNet.DataMapper.Configuration.DomSqlMapBuilder.Build(XmlDocument document, Boolean useConfigFileWatcher)
在 IBatisNet.DataMapper.Configuration.DomSqlMapBuilder.Configure(String resource)
在 IBatisHelper.ibatisInit(String sqlmapPath) 位置 c:\Users\Administrator\Documents\Visual Studio 2012\Projects\UserInfo\UserInfo\IBatisHelper.cs:行号 24
----------------------------------------

请高手指教!!谢谢

应用程序配置文件(App.config)是标准的 XML 文件,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\d1,3\.\d1,3\.\d1,3\.\d1,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\d1,3\.\d1,3\.\d1,3\.\d1,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);


参考技术A 这错误要么就是你的sql配置文件路径不对,要么就是配置文件内部格式不正确。
你只贴出了堆栈,没有贴出错误信息,看不出是什么错误。
ibatis是开源的,可以下载源代码加入工程,一起调试,就知道哪错了。本回答被提问者采纳

以上是关于c#读取Config文件的问题的主要内容,如果未能解决你的问题,请参考以下文章

C#如何读取config配置文件数据?

如何从 C# 读取 VB.NET 项目中的“app.config”文件

在 C# 运行时读取、写入和更新 app.config 文件中的连接字符串

C# Windows 服务 - 从 ini 或 App.config 文件中读取

无法从 C# 中的控制台应用程序中读取配置文件

如何在单个项目中从 C# 中的多个配置文件中读取值?