ASP.NET Core 6 基础入门系列(18) ASP.NET Core 中的配置介绍
- ASP.NET Core 6 基础入门系列(17) ASP.NET Core 的核心对象WebApplication与WebApplicationBuilder
- ASP.NET Core 6 基础入门系列(16) 项目的 web.config 文件介绍
- ASP.NET Core 6 基础入门系列(15) 项目在IIS下部署的两种进程托管模型
- ASP.NET Core 6 基础入门系列(14) 项目发布与IIS部署
- ASP.NET Core 6 基础入门系列(13) Web 服务器介绍
- ASP.NET Core 6 基础入门系列(12) 项目的多种启动方式及问题
- ASP.NET Core 6 基础入门系列(11) 项目结构详解之项目入口Program.cs
- ASP.NET Core 6 基础入门系列(10) 项目结构详解之appsettings.json
- ASP.NET Core 6 基础入门系列(9) 项目结构详解之launchSettings.json
- ASP.NET Core 6 基础入门系列(8) 项目结构详解之MVC
- ASP.NET Core 6 基础入门系列(7) 项目结构详解之wwwroot
- ASP.NET Core 6 基础入门系列(6) 项目结构详解之依赖项
- ASP.NET Core 6 基础入门系列(5) 项目结构详解之项目文件管理
- ASP.NET Core 6 基础入门系列(4) 项目结构简介
- ASP.NET Core 6 基础入门系列(3) 新建 ASP.NET Core MVC 6.0 项目
- ASP.NET Core 6 基础入门系列(2) 开发环境准备
- ASP.NET Core 6 基础入门系列(1) ASP.NET Core 6 简介
ASP.NET Core 中的应用程序配置是使用一个或多个配置提供程序执行的。 配置提供程序使用各种配置源从键值对读取配置数据:
- 设置文件,例如
appsettings.json
- 环境变量
- Azure Key Vault
- Azure 应用程序配置
- 命令行参数
- 已安装或已创建的自定义提供程序
- 目录文件
- 内存中的 .NET 对象
新建的ASP.NET Core 项目中首先见到的就是 launchSettings.json 与 appsettings.json 文件,需要了解详细信息可以参考我之前的博客
- ASP.NET Core 6 基础入门系列(10) 项目结构详解之appsettings.json
- ASP.NET Core 6 基础入门系列(9) 项目结构详解之launchSettings.json
下表显示了 ASP.NET Core 应用可用的配置提供程序
按照指定的配置提供程序的顺序读取配置源。 代码中的配置提供程序应以特定顺序排列,从而满足应用所需的基础配置源的优先级。
配置提供程序的典型顺序为:
(1)appsettings.json
(2)appsettings.{Environment}.json
(3)用户机密
(4)使用环境变量配置提供程序通过环境变量提供。
(5)使用命令行配置提供程序通过命令行参数提供。
建议:通常的做法是将命令行配置提供程序添加到一系列提供程序的末尾,使命令行参数能够替代由其他提供程序设置的配置。
下面通过程序来读取应用程序中已启用的配置提供程序
(1)通过IISExpress方式以及项目方式调试运行,获取到的已启用的配置提供程序列表如下
其中有一个 JsonConfigurationProvider for‘appsettings.Development.json’提供程序,原因是 launchSettings.json 配置的环境信息就是 "ASPNETCORE_ENVIRONMENT": "Development" 模式
把"ASPNETCORE_ENVIRONMENT" 改成 "Production",再次运行,读取的就是 Production.json文件
(2)通过 dotnet run 命令访问程序(Development模式),获取到的已启用的配置提供程序列表如下
其中有一个 JsonConfigurationProvider for‘appsettings.Development.json’提供程序,原因与上述相同。
(3)将项目发布后访问,获取到的已启用的配置提供程序列表如下
发布后的程序默认是 Production 生产模式。
后来添加的配置提供程序具有更高的优先级并且会替代之前的密钥设置。 例如,如果
appsettings.json
和环境中都设置了MyKey
,则使用环境值。 通过默认配置提供程序,命令行配置提供程序 将替代其他所有提供程序。
以下列表包含优先级从低到高的默认主机配置源:
1、使用 环境变量配置提供程序 通过以 DOTNET_
为前缀的环境变量提供。
2、使用 命令行配置提供程序 通过命令行参数提供。
3、使用 环境变量配置提供程序 通过以 ASPNETCORE_
为前缀的环境变量提供。
在主机和应用程序配置中设置配置值时,将使用应用程序配置。
在主机配置中以 ASPNETCORE_
为前缀的环境变量的优先级高于命令行参数的原因如下:
应用程序配置会返回到主机配置,所以您可能会想,为什么在主机配置中,命令行参数会以较低的优先级再次添加。答案是,在初始化 WebApplicationBuilder 和 IHostBuilder.Build() 的早期阶段,应用程序配置尚未构建。
由于我们希望允许命令行参数在默认情况下控制环境名称(这对于构建应用程序配置非常重要,因为这决定了要加载哪些 appsettings.{environment}.json),因此命令行被添加了两次作为配置源。
通过 dotnet new 命令或 Visual Studio 创建的 ASP.NET Core Web 应用会生成以下代码:
var builder = WebApplication.CreateBuilder(args);
WebApplication.CreateBuilder 使用预配置的默认值初始化类的新实例。 经过初始化的 WebApplicationBuilder
(builder
) 按照以下顺序为应用提供默认配置(优先级从低到高):
1、回退到上一部分所述的默认主机配置。
2、使用 JSON 配置提供程序 读取 appsettings.json 文件。
3、使用 JSON 配置提供程序 读取 appsettings.{Environment}.json
文件。 例如,appsettings.Production.json
和 appsettings.Development.json
。
4、应用在环境中运行时的 用户机密。
5、使用 非前缀环境变量配置提供程序 通过非前缀环境变量提供。
6、使用 命令行配置提供程序 通过命令行参数提供。
22
22
22
参考文献:
- 《ASP.NET Core 中的配置》https://learn.microsoft.com/zh-cn/aspnet/core/fundamentals/configuration/?view=aspnetcore-6.0
成在管理,败在经验;嬴在选择,输在不学! 贵在坚持!
个人作品
BIMFace.SDK.NET
开源地址:https://gitee.com/NAlps/BIMFace.SDK
系列博客:https://www.cnblogs.com/SavionZhang/p/11424431.html
系列视频:https://www.cnblogs.com/SavionZhang/p/14258393.html
技术栈
1、AI、DeepSeek、MiniMax、通义千问
2、Visual Studio、.NET Core/.NET、MVC、Web API、RESTful API、gRPC、SignalR、Java、Python
3、jQuery、Vue.js、Bootstrap、ElementUI
4、数据库:分库分表、读写分离、SQLServer、MySQL、PostgreSQL、Redis、MongoDB、ElasticSearch、达梦DM、GaussDB、OpenGauss
5、架构:DDD、ABP、SpringBoot、jFinal
6、环境:跨平台、Windows、Linux
7、移动App:Android、IOS、HarmonyOS、微信小程序、钉钉、uni-app、MAUI
8、分布式、高并发、云原生、微服务、Docker、CI/CD、DevOps、K8S;Dapr、RabbitMQ、Kafka、RPC、Elasticsearch
欢迎关注作者头条号 张传宁IT讲堂,获取更多IT文章、视频等优质内容。
出处:www.cnblogs.com/SavionZhang
作者:张传宁 技术顾问、培训讲师、微软MCP、系统架构设计师、系统集成项目管理工程师、科技部创新工程师。
专注于企业级通用开发平台、工作流引擎、自动化项目(代码)生成器、SOA 、DDD、 云原生(Docker、微服务、DevOps、CI/CD);PDF、CAD、BIM 审图等研究与应用。
多次参与电子政务、图书教育、生产制造等企业级大型项目研发与管理工作。
熟悉中小企业软件开发过程:可行调研、需求分析、架构设计、编码测试、实施部署、项目管理。通过技术与管理帮助中小企业实现互联网转型升级全流程解决方案。
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。
如有问题,可以通过邮件905442693@qq.com联系。共同交流、互相学习。
如果您觉得文章对您有帮助,请点击文章右下角【推荐】。您的鼓励是作者持续创作的最大动力!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· .NET10 - 预览版1新功能体验(一)