gpt4 book ai didi

c# - 在 C# 中通过主机名自动加载配置

转载 作者:行者123 更新时间:2023-11-30 19:42:10 24 4
gpt4 key购买 nike

我们在不同的机器上开发一个项目。每台机器都有自己的数据库连接。

目前我们使用外部文件从 app.config 中加载数据库配置

<connectionStrings configSource="DB.config" />

现在我希望能够保存不同的文件,例如 DB.BobsPC.configDB.JacksPC.config,其中 BobsPCJacksPC 是代码被调试机器的主机名。应该自动使用正确主机的配置。

类似于:

<connectionStrings configSource="DB.[hostname].config" />

有没有聪明的方法来做到这一点?

最佳答案

您可以使用 "XML-Document-Transform Syntax"通常,此语法适用于 Web 项目,但您可以调整它以用于所有类型的项目。

您必须通过添加/更新 TransformXml-Task 来修改您的项目文件(例如 .csproj)。在下面的示例中,通过在 App.config 上应用转换,在编译期间执行转换。如您所见,任务引用了 $(Configuration) 变量,因此转换命令存储在例如在 App.DEBUG.config 或 App.RELEASE.config 中。您可以将其更改为您喜欢的任何 msbuild 变量。如果我没记错的话它是 $(COMPUTERNAME) 所以你必须将你的转换放入 App.MyMachineName.config。

<UsingTask TaskName="TransformXml" 
AssemblyFile="C:\Program Files\MSBuild\Microsoft\VisualStudio\v10.0\Web\Microsoft.Web.Publishing.Tasks.dll"/>
<Target Name="AfterBuild">
<!-- use App.$(COMPUTERNAME).config for specific machine configuration -->
<TransformXml Source="App.config"
Condition="Exists('App.$(Configuration).config')"
Transform="App.$(Configuration).config"
Destination="$(OutDir)$(AssemblyName).dll.config"/>
</Target>

完整说明可在 german blog 中找到。 .

这就是您的机器特定配置的样子:

<?xml version="1.0"?>
<!-- "App.MyMachineName.config" - File name corresponds to the transformation task -->
<configuration xmlns:xdt="http://schemas.microsoft.com/XML-Document-Transform">
<connectionStrings>
<add name="MyDbConnection"
connectionString="Data Source=MyServer;Initial Catalog=MyDb;"
providerName="System.Data.SqlClient"
xdt:Transform="SetAttributes"
xdt:Locator="Match(name)"/>
</connectionStrings>
</configuration>

或者,您可以使用 XSL Syntax

关于c# - 在 C# 中通过主机名自动加载配置,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17927818/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com