如何动态更改app.config文件中的connectionString?
我有一个用windows表单编写的应用程序,c#3.0和Linq到Sql。我需要在安装应用程序时更改连接字符串。我怎么做的?
当用户安装程序时,它必须显示一个表单,如果存在,则可以选择更改连接字符串,如果不存在则添加一个。
答案 0 :(得分:6)
如果您使用的是.NET部署项目,可以使用自定义操作来实现此目的。
答案 1 :(得分:5)
使用安装程序中的设置使用appSettings块编写辅助配置文件。在主配置文件中,使用appSettings中的file属性引用第二个配置文件,如下所示:
<appSettings file="User.config">
辅助配置中的设置将覆盖主配置中的任何匹配键。
在您的安装程序中:
public override void Install(IDictionary stateSaver)
{
base.Install(stateSaver);
string server = Context.Parameters["Server"];
string port = Context.Parameters["Port"];
string targetDir = Context.Parameters["TargetDir"];
// Build your connection string from user-input parameters and add them to dictionary
WriteAppConfig(targetDir, server, port);
}
private void WriteAppConfig(string targetDir, string server, string port)
{
string configFilePath = Path.Combine(targetDir, "User.config");
IDictionary<string, string> userConfiguration = new Dictionary<string, string>();
userConfiguration["Server"] = server;
userConfiguration["Port"] = port;
ConfigGenerator.WriteExternalAppConfig(configFilePath, userConfiguration);
}
public class ConfigGenerator
{
public static void WriteExternalAppConfig(string configFilePath, IDictionary<string, string> userConfiguration)
{
using (XmlTextWriter xw = new XmlTextWriter(configFilePath, Encoding.UTF8))
{
xw.Formatting = Formatting.Indented;
xw.Indentation = 4;
xw.WriteStartDocument();
xw.WriteStartElement("appSettings");
foreach (KeyValuePair<string, string> pair in userConfiguration)
{
xw.WriteStartElement("add");
xw.WriteAttributeString("key", pair.Key);
xw.WriteAttributeString("value", pair.Value);
xw.WriteEndElement();
}
xw.WriteEndElement();
xw.WriteEndDocument();
}
}
}
答案 2 :(得分:0)
结帐this question。它具有通过代码动态更改app.config中的值所需的内容。