在 C# .NET Framework 中使用 ConfigurationBuilder 我的应用服务设置去了哪里?

Using ConfigurationBuilder in C# .NET Framework where did my App Service settings go?

我正在尝试将源代码中的环境特定变量与App.config文件[=25]的现有配置相结合=] 和 Azure 应用服务中的 AppSettings 和 ConnectionStrings 用于 Azure WebJob (.NET Framework)。在应用服务中拥有所有环境变量在进行更改时可能会非常耗时。

浏览了一堆关于 App.config-tranformations 和 Azure WebJobs 主题的博客和帖子之后,添加 ConfigurationBuilder 似乎是覆盖环境特定(非机密)设置的相当新的方法。如果我没记错的话,它是在 .NET 4.7.1 中添加的。它似乎比 SlowCheetah 和脚本更有前途。

但是在添加自定义 ConfigurationBuilder 之后(类似于 link 1 中提到的)应用服务中指定的应用设置不再包含在结果中。我最终只得到来自 app.config 文件和自定义 ConfigurationBuilder 的条目。在配置条目中创建自定义条目时是否需要检索这些应用程序设置?或者我应该扩展 EnvironmentVariables 并修改那些 XmlNode 条目?

  1. https://jeffreyfritz.com/2017/11/modern-configuration-for-asp-net-4-7-1-with-configurationbuilders/
  2. https://docs.microsoft.com/en-us/dotnet/api/system.configuration.configurationbuilder?view=netframework-4.7.2

查看以下链接,它们似乎解决了与您描述的问题类似的问题:

希望对您有所帮助!

事实证明,有一些事情需要考虑,并且在有可能的路线之前需要做出一些假设。我最终在 documentation.

的帮助下编写了自己的配置生成器

鉴于使用的是 .NETFramework 而不是 AspNetCore(在这种情况下特别是 .NETFramework 4.7.1)。似乎 Azure 提供的应用服务确实使用了某种开箱即用的配置生成器。似乎没有任何指定配置生成器的 Web.config 将包含所有 Azure 应用服务设置。它甚至会添加 Web.config 中不存在的设置。所以不使用脚手架;这可能会让事情更容易掌握,但微软可能有充分的理由不以这种方式实现事情。添加您自己的配置生成器将使从 Azure 应用服务读取的任何设置不再被读取。我假设可能是因为您刚刚替换了一个 "hidden" 配置生成器并且现在需要自己完成这项工作。

查看 source code 我做了另一个相关发现,这对我编写自己的配置生成器有很大帮助。配置构建器的工作方式似乎有两种典型的操作模式:贪婪或 "strict"。我建议不要同时使用两者。贪心模式意味着无论密钥最初是否存在于 Web.config 中,都会添加在环境变量中找到的所有设置。 "strict" 模式意味着它只替换从一开始就存在的键的值。

我最终从环境变量中读取了相关设置。但是要找到所使用的适当前缀的可靠文档有点棘手(尽管可以读取所有变量)。但是最常见的are roughly(我认为):

  • APPSETTING_(相信这些对应于应用程序服务设置,如果我没记错的话)
  • SQLServerSQLCONNSTR_
  • SQLAZURECONNSTR_

无论如何,我的特定场景是 运行 应用服务 Web 应用程序和 WebJob 在同一个插槽中。为 WebJob 附加 Web 应用程序的设置似乎没有吸引力,也没有必要。所以我写了一个 "strict" 配置生成器,它以一种谨慎的方式从源中级联所有设置。这意味着 Azure 应用服务中指定的任何设置也必须在 Web.config 中定义。如果接下来没有这样的设置,则包括所选配置的任何转换值。最后使用了Web.config中的默认值

总而言之,如果您在 .NETFramework 中编写自己的配置生成器,您可能需要做一些工作来包含应用服务应用程序设置或连接字符串。您可能想要研究 ConfigurationBuilder-class 及其各自的方法 ProcessConfigurationSection 以获取类型 classes 或 ProcessRawXml,或许还可以检查一些 real world examples