在安装时更改app.config

时间:2009-04-24 15:17:46

标签: c# linq deployment

如何动态更改app.config文件中的connectionString?

我有一个用windows表单编写的应用程序,c#3.0和Linq到Sql。我需要在安装应用程序时更改连接字符串。我怎么做的?

当用户安装程序时,它必须显示一个表单,如果存在,则可以选择更改连接字符串,如果不存在则添加一个。

3 个答案:

答案 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中的值所需的内容。