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 简介
web.config
文件由 IIS 和 web.config
读取,用于使用 IIS 配置已托管的应用。
为了正确设置 ASP.NET Core Module,web.config
文件必须存在于已部署应用的内容根路径(通常为应用基路径)中。 该位置与向 IIS 提供的网站物理路径相同。 若要使用 Web 部署发布多个应用,应用的根路径中需要包含 web.config
文件。
敏感文件存在于应用的物理路径中,如 {ASSEMBLY}.runtimeconfig.json
、{ASSEMBLY}.xml
(XML 文档注释)和 {ASSEMBLY}.deps.json
,其中 {ASSEMBLY}
占位符为程序集名称。
- 如果有
web.config
文件且站点正常启动时,IIS 在收到敏感文件请求时不会提供这些敏感文件。 - 如果
web.config
文件缺失、名字错误或者无法将站点配置为正常启动,IIS 可能会公开提供敏感文件。
web.config 文件必须始终存在于部署中、名称正确以及能够将站点配置为正常启动。 切勿从生产部署中删除 web.config 文件。
- 如果项目中没有
web.config
文件,则该文件是使用正确的processPath
和arguments
(用于配置 ASP.NET Core Module)创建的,并且已被移到web.config
中。- 如果项目中有
web.config
文件(在VS中手动添加的),则该文件是通过正确的processPath
和arguments
(用于配置 ASP.NET Core 模块)转换的,并且已被移到发布的输出中。 转换不会修改文件中的 IIS 配置设置。正常项目开发过程中,不需要手动添加web.conifg文件,项目发布后在生成的 web.config 文件中做适当的调整即可满足大部分的项目应用需求。
发布项目时,web.config
文件的创建、转换和发布是由 MSBuild 目标 (_TransformWebConfig
) 处理的。 此目标位于 Web SDK 目标 (Microsoft.NET.Sdk.Web
) 中。
<Project Sdk="Microsoft.NET.Sdk.Web">
为了防止 Web SDK 转换 web.config
文件,请在项目文件中使用 <IsTransformWebConfigDisabled>
属性:
禁用 Web SDK 对文件的转换时,processPath
和 arguments
应由开发人员手动设置(不会被发布功能覆盖)。 有关详细信息,请参阅用于 IIS 的 ASP.NET Core 模块 (ANCM)。
在站点的 web.config 文件中使用 system.webServer 节点的 aspNetCore 部分配置 ASP.NET Core 模块。
aspNetCore 元素的属性如下
可以为 processPath
属性中的进程指定环境变量。 使用 <environmentVariables>
集合元素的 <environmentVariable>
子元素指定环境变量。 本部分中设置的环境变量优先于系统环境变量。
以下示例在 web.config
中设置了两个环境变量。 ASPNETCORE_ENVIRONMENT
将应用的环境配置为 Development
。 开发人员可能会暂时在 web.config
文件中设置此值,以便在调试应用异常时强制加载开发人员异常页面。 CONFIG_DIR
是用户定义的环境变量的一个示例,其中开发人员已写入可在启动时读取值的代码以便形成用于加载应用配置文件的路径。
<aspNetCore processPath="dotnet" arguments=".\MyApp.dll" stdoutLogEnabled="false" stdoutLogFile=".\logs\stdout" hostingModel="inprocess"> <environmentVariables> <environmentVariable name="ASPNETCORE_ENVIRONMENT" value="Development" /> <environmentVariable name="CONFIG_DIR" value="f:\application_config" /> </environmentVariables> </aspNetCore>
直接在 web.config 中设置环境的替代方法是将属性包含在发布配置文件 (.pubxml)
或项目文件中
此方法在发布项目时设置 web.config 中的环境:
<PropertyGroup> <EnvironmentName>Development</EnvironmentName> </PropertyGroup>
参考文献:
- 《web.config 文件》https://learn.microsoft.com/zh-cn/aspnet/core/host-and-deploy/iis/web-config?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 加持,快人一步
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 记一次.NET内存居高不下排查解决与启示