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

Posted

技术标签:

【中文标题】在 C# 运行时读取、写入和更新 app.config 文件中的连接字符串【英文标题】:read,write and update connectionstring in app.config file at run time in C# 【发布时间】:2017-08-12 15:01:03 【问题描述】:

我为连接设置创建了一个表单,用户可以在其中更新服务器名称、数据库以及用户 ID 和密码。我已将连接字符串存储在 app.config 文件中。

我的问题是,如何在运行时更新app.config文件中的连接字符串以及如何在第一时间通过表单上的文本框更改连接字符串的信息,文本框将显示信息第一次后的服务器名、id、密码

这里是我的 app.config

    <?xml version="1.0" encoding="utf-8" ?>
<configuration>
    <configSections>
        <sectionGroup name="userSettings" type="System.Configuration.UserSettingsGroup, System, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" >
            <section name="Data123.Properties.Settings" type="System.Configuration.ClientSettingsSection, System, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" allowExeDefinition="MachineToLocalUser" requirePermission="false" />
        </sectionGroup>   
    </configSections>
  <connectionStrings>
   <add name="Data123Entities" connectionString="metadata=res://*/Data123DB.csdl|res://*/Data123DB.ssdl|res://*/Data123DB.msl;provider=System.Data.SqlClient;provider connection string=&quot;data source=nguyenduyhai;initial catalog=Data123;persist security info=True;user id=sa;password=1234567;MultipleActiveResultSets=True;App=EntityFramework&quot;" providerName="System.Data.EntityClient" />
    <!--<add name="Data123Entities" connectionString="metadata=res://*/Data123DB.csdl|res://*/Data123DB.ssdl|res://*/Data123DB.msl;provider=System.Data.SqlClient;provider connection string=&quot;data source=NGUYENDUYHAI\SQLEXPRESS;initial catalog=Data123;persist security info=True;user id=sa;password=1234567;MultipleActiveResultSets=True;App=EntityFramework&quot;" providerName="System.Data.EntityClient" />-->
  </connectionStrings>
</configuration>

这里是我正在尝试但不起作用的代码,请帮助我

     void saveconect(string address,string id,string pass)


            var config = ConfigurationManager.OpenExeConfiguration(ConfigurationUserLevel.None);
            var connectionStringsSection = (ConnectionStringsSection)config.GetSection("connectionStrings");
            connectionStringsSection.ConnectionStrings["Data123Entities"].ConnectionString = "data source=" + address + ";initial catalog=" + "Data123" + ";user id=" + id + ";password=" + pass + "";
            config.Save(ConfigurationSaveMode.Modified, true);
            ConfigurationManager.RefreshSection("connectionStrings");





 private void buttonUpdate_Click(object sender, EventArgs e)
    


        saveconect(textboxServerAddress.Text, textBoxUserID.Text, textBoxPassword.Text);
    

【问题讨论】:

从配置中读取很容易,但使用 Configuration Manager 命名空间写入它们总是很麻烦。直接使用 XML 即可:***.com/a/37163251/495455 你能指导我详细一点吗,如果你能指导我,我很感激 请参考以下链接***.com/questions/502411/… 【参考方案1】:

您是否尝试在发布文件夹中运行应用程序? 因为在 Debug 模式下不会改变。

【讨论】:

当然我在发布文件夹中运行它但仍然没有工作,你认为我的代码有错误吗?【参考方案2】:

使用 System.Xml.Linq; 会是这样的:

var doc = XElement.Load(fileName); 
var target = doc.Element("configuration").Elements("configurationStrings").Where(e => e.Element("name").Value == "Data123Entities").Single(); 
target.Element("connectionString").Value = "metadata=res://*/Data123DB.csdl|res://*/Data123DB.ssdl|res://*/Data123DB.msl;provider=System.Data.SqlClient;provider connection string=&quot;data source=" + dataSource + ";initial catalog=" + initCatalog + ";persist security info=True;user id=sa;password=1234567;MultipleActiveResultSets=True;App=EntityFramework&quot;"
doc.Save(fileName);

【讨论】:

我的文件名 = AppDomain.CurrentDomain.SetupInformation.ConfigurationFile 但我知道了,我该怎么办 System.NullReferenceException is unhandled Message: An unhandled exception of type 'System.NullReferenceException' occurred in ShinEtsu.exe Additional信息:对象引用未设置为对象的实例。 Object reference not set to an instance of an object. 是最流行的 .net 错误消息...对不起,您必须通过谷歌搜索解决它......它太容易了 - 单步执行代码,直到你得到异常并在它失败的那一行查看什么对象为空!!! 最后一个问题你给我这个 var target = doc.Element("configuration").Elements("configurationStrings").Where(e => e.Element("name").Value = = "Data123Entities").Single();但我在上面的 app.config 中没有看到任何“configurationStrings”部分是错误还是我遗漏了什么?

以上是关于在 C# 运行时读取、写入和更新 app.config 文件中的连接字符串的主要内容,如果未能解决你的问题,请参考以下文章

使用 IPC C# 时如何有效地从管道流中读取

Asp net core 在运行时读取或写入视图

c++和c#之间的共享内存同步

C#读取Excle文件时报错,怎么处理?

如何在 C# 中调用多个控件

如何在 C# .NET 中保持 TCP 连接打开并执行多次写入/读取?