根据生成配置更改 Windows 窗体中的连接字符串



类似于在 ASP.NET 中拥有多个Web.config,是否可以根据构建配置拥有多个App.config?

我想更改我的连接字符串,所以如果我正在构建配置test,连接字符串应该是:

"Server=test;Initial Catalog=test..."

如果我针对test2构建,则连接字符串将为:

"Server=anotherserver; Initial Catalog=test2..."

目前,我正在手动执行此操作,所以我想知道如何自动执行此操作?

尽管它们本身不受支持,但您也可以对 Windows 窗体项目 (App.config) 进行 XML 转换,而不仅仅是 Web 应用程序项目。

有一个 VS 插件可以实现这种支持,虽然我从未尝试过,但对于安装了 VS 的环境,我会推荐它,因为它是由至少一位Microsoft员工创作的,我相信他对 MSBuild 有深入的了解,因为他已经写了一本关于这个主题的书。

慢猎豹 - XML 转换

我不知道 SlowCheetah 是否为未安装 VS 的 CI 服务器提供支持,所以我还将基于包含自定义目标文件抛出另一个解决方案。

Visual Studio App.config XML Transformation

(无耻的插头通知,我是上面那个的原作者)

我们在这里使用的策略似乎效果很好。我们每个解决方案都有一个 Web.config。我认为这也适用于 app.configs,但从未尝试过。你创建一个类,称之为,例如,ConfigurationManager。在类中应该有这样的代码:

public static class ConfigurationManager
{
    private static NameValueCollection _appSettings = new NameValueCollection();
    private static ConnectionStringSettingsCollection _connSettings = new ConnectionStringSettingsCollection();
    private enum SettingsType {App, Connection};
    public static NameValueCollection AppSettings
    {
        get 
        {
            if (_appSettings.Count == 0)
            {
                LoadEnvironmentSettings(SettingsType.App);
            }
            return _appSettings;
        }
    }
    public static ConnectionStringSettingsCollection ConnectionStrings
    {
        get
        {
            if (_connSettings.Count == 0)
            {
                LoadEnvironmentSettings(SettingsType.Connection);
            }
            return _connSettings;
        }
    }
    private static void LoadEnvironmentSettings(SettingsType settingsType)
    {
        string strEnvironment = string.Empty, strSeparator = ".";
        if (ConfigurationManager.AppSettings.HasKeys())
        {
            strEnvironment = ConfigurationManager.AppSettings["Environment"];
            if (!String.IsNullOrEmpty(strEnvironment))
            {
                strEnvironment += strSeparator;
                switch (settingsType)
                {
                    case SettingsType.App:
                        LoadAppSettings(strEnvironment.ToUpper());
                        break;
                    case SettingsType.Connection:
                        LoadConnectionSettings(strEnvironment.ToUpper());
                        break;
                }
            }
            else //that part should never happen
            {
                throw new Exception("Missing Environment AppSetting");
            }
        }
    }
    private static void LoadAppSettings(string environmentType)
    {
        string appKey = string.Empty;
        foreach (string key in ConfigurationManager.AppSettings.AllKeys)
        {
            if (key.StartsWith(environmentType))
            {
                appKey = key.Replace(environmentType, string.Empty);
                _appSettings.Add(appKey, ConfigurationManager.AppSettings[key]);
            }
        }
    }
    private static void LoadConnectionSettings(string environmentType)
    {
        //ConnectionStringSettings connStrings = new ConnectionStringSettings();
        string connKey = string.Empty;
        foreach (ConnectionStringSettings str in ConfigurationManager.ConnectionStrings)
        {
            if (str.Name.StartsWith(environmentType))
            {
                connKey = str.Name.Replace(environmentType, string.Empty);
                _connSettings.Add(new ConnectionStringSettings(connKey, str.ConnectionString));
            }
        }
    }
}

您需要添加 System、System.Collections.Generic、System.Collections.Specialized、System.Configuration 和 System.Text。确保您的类与正在处理的项目位于同一命名空间中。然后,在配置文件中添加两个(或更多)键,例如,

<add name="TEST.MyConnectionString" connectionString="Data Source=TESTServer;Initial Catalog=MyDatabase;user id=MyUser;pwd=Mypwd" />
<add name="TEST2.MyConnectionString" connectionString="Data Source=TEST2Server;Initial Catalog=MyDatabase;user id=MyUser;pwd=Mypwd" />

最后,在您的 machine.config 中,您可以在 appSettings 中添加以下内容:

<add key="Environment" value="TEST"/>

<add key="Environment" value="TEST2"/>

取决于你想做什么。我们通常放置 DEV、暂存和 PROD 密钥,然后在三个不同的 DEV、暂存和 PROD 服务器上使用不同的 machine.config 文件。希望这有帮助

最新更新