3

我正在开发 win 表单,并且我有应用程序配置文件。如何写入应用程序配置文件的连接字符串部分?我当前的 App.Config 文件是

  <?xml version="1.0" encoding="utf-8" ?>
<configuration>
  <connectionStrings>
     <add name="MyDbConnection" connectionString="" providerName="System.Data.OleDb" />
</connectionStrings>
</configuration>

我更改连接字符串的 C# 代码是

var Config = ConfigurationManager.OpenExeConfiguration(ConfigurationUserLevel.None);
                var connectionStringsSection = (ConnectionStringsSection)Config.GetSection("connectionStrings");
                ConfigurationManager.ConnectionStrings["MyDbConnection"].ConnectionString = "Provider=Microsoft.ACE.OLEDB.12.0;Data Source=" + FilePath + "";
                Config.Save();
                ConfigurationManager.RefreshSection("connectionStrings");

但是在第 3 行会生成异常

configuration error exception this configuration is read only

更改连接字符串的代码是从外部类调用的。我不知道应该将代码放在哪里来覆盖 IsReadonly() 方法。应用程序配置也没有文件隐藏代码。

4

2 回答 2

2

应用程序配置

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
   <connectionStrings>
      <add name="MyDBConnectionString" providerName="System.Data.SqlClient"
            connectionString="Data Source=localhost;Initial Catalog=MySQLServerDB; Integrated Security=true" />
   </connectionStrings>
</configuration>

当您将连接字符串保存在 App.config 文件中时,您可以使用 System.Configuration.ConfigurationManager 类在代码中读取此连接字符串。

ConnectionStringSettings  conSettings = ConfigurationManager.ConnectionStrings["MyDBConnectionString"];

ConnectionStringsSettings 类提供了在程序中读取连接字符串设置的属性,如下所示:

string name = conSettings.Name;
string providerName = conSettings.ProviderName;
string connectionString = conSettings.ConnectionString;
于 2013-01-12T10:55:24.070 回答
1

要在App.config文件中写入连接字符串,您可以使用:

创建两个设置,例如:AppConnectionString(类型:字符串)和ServerConnectionString(类型:ConnectionString)

修改设置代码,在获取ServerConnectionString设置的属性时将返回值更改为AppConnectionString

通过这样做,您可以修改、保存或重新加载AppConnectionString设置,当您在应用程序上引用ServerConnectionString时,它将返回AppConnectionString设置。尝试一下。

于 2014-01-24T07:38:10.577 回答