0

0

Web.config customErrors配置 IIS错误页面的重定向模式

月夜之吻

月夜之吻

发布时间:2026-02-23 00:11:21

|

317人浏览过

|

来源于php中文网

原创

customerrors 的 redirect 模式仅在 iis 集成模式下生效,经典模式下无法处理 iis 层错误;需配合 httperrors 且正确配置 statuscode 子节点与 mode 设置。

web.config customerrors配置 iis错误页面的重定向模式

customErrors 的 redirect 模式只在 IIS 集成管道下生效

如果你在 IIS 经典模式(Classic Mode)下配置了 <customerrors mode="On" redirect="~/Error/500.aspx"></customerrors>,但 500 错误仍显示默认黄页或空白页,大概率是管道模式不匹配。IIS 集成模式(Integrated Mode)才真正接管 ASP.NET 的错误生命周期,经典模式下 customErrors 仅处理托管异常,对 IIS 层面的 500(比如 web.config 解析失败、权限拒绝)完全无响应。

实操建议:

  • 确认应用池管道模式:IIS 管理器 → 应用池 → 右键「高级设置」→ 查看 Managed Pipeline Mode 是否为 Integrated
  • 若必须用经典模式,customErrors 无法兜底非托管错误,得靠 <httperrors></httperrors>(IIS 级)配合,且需关闭 existingResponse="Auto" 干扰
  • redirect 路径必须是相对应用根目录的 URL,不能是物理路径或绝对 URL(如 redirect="http://example.com/error" 会被忽略)

mode="RemoteOnly" 下本地调试看不到自定义页

开发时经常发现:本地运行时抛出异常,却看到详细的黄页堆栈,而不是预期的 redirect 页面。这是因为 mode="RemoteOnly" 会检测 Request.IsLocal,只要请求来自 127.0.0.1 或本机主机名(包括 localhost),就强制显示详细错误——这是设计行为,不是 bug。

实操建议:

  • 调试阶段想预览自定义页,临时改成 mode="On",上线前务必改回 RemoteOnly(避免泄露敏感信息)
  • 不要依赖修改 hosts 把 localhost 指向其他 IP 来绕过,IsLocal 判定逻辑更复杂,可能失效
  • 如果用 VS 内置服务器(Cassini)或 Kestrel + IIS Express,IsLocal 依然为 true,RemoteOnly 无效

HTTP 状态码不匹配导致重定向失败

配置了 redirect="~/Error/500.aspx",但 404 请求却跳转到了 500 页面,或者 500 错误反而触发了 404 页面——根本原因是 customErrors 默认只按异常类型(而非 HTTP 状态码)分发,它没有原生支持按状态码路由;你看到的“按状态码跳转”,其实是靠 <error statuscode="404" redirect="..."></error> 子节点实现的,而这个子节点必须和 mode 同级,且只在 mode="On""RemoteOnly" 下生效。

Pokecut
Pokecut

AI图片编辑处理工具,拥有超过50多种AI功能

下载

实操建议:

  • 要精确控制不同状态码的页面,必须显式声明 <error statuscode="404" redirect="~/Error/NotFound.aspx"></error> 等条目
  • statusCode 值必须是整数(如 404),不能写成 "NotFound"HttpStatusCode.NotFound
  • 若同时配置了顶层 redirect 和子 <error></error>,子项优先级更高;但子项未覆盖的状态码会 fallback 到顶层 redirect
  • IIS 的 <httperrors></httperrors> 是更底层的机制,当 customErrors 不生效时(如静态文件 404),它才起作用,二者常需协同

customErrors 不捕获 web.config 解析错误或启动异常

最常见的幻觉是:把 customErrors 当作“万能错误兜底”。实际上,它只在 ASP.NET 托管管线中生效。一旦 web.config 格式错误、<compilation></compilation> 引用不存在的 DLL、Global.asax 构造函数抛异常,甚至 Application_Start 中崩溃,请求根本进不到 customErrors 的作用域——IIS 会直接返回 500.19、500.21 等子状态码错误,此时只有 <httperrors></httperrors> 可干预。

实操建议:

  • 验证 customErrors 是否生效的最快方式:在某个 .aspx 页面里手动 throw new Exception(),而不是改配置或删文件
  • web.config 语法错误 → 查看 IIS 日志中的 0x8007000d 或检查事件查看器里的 ConfigurationErrorsException
  • Application_Start 失败 → 错误日志在 Windows 事件查看器的 ASP.NET x.x.x 日志源下,customErrors 完全不参与

真正难搞的是那些跨层错误:既不在 ASP.NET 管线内、又没被 IIS <httperrors></httperrors> 捕获的场景(比如某些模块初始化失败)。这时候连重定向都不可靠,得靠日志+监控提前暴露问题。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
Node.js后端开发与Express框架实践
Node.js后端开发与Express框架实践

本专题针对初中级 Node.js 开发者,系统讲解如何使用 Express 框架搭建高性能后端服务。内容包括路由设计、中间件开发、数据库集成、API 安全与异常处理,以及 RESTful API 的设计与优化。通过实际项目演示,帮助开发者快速掌握 Node.js 后端开发流程。

219

2026.02.10

pdf怎么转换成xml格式
pdf怎么转换成xml格式

将 pdf 转换为 xml 的方法:1. 使用在线转换器;2. 使用桌面软件(如 adobe acrobat、itext);3. 使用命令行工具(如 pdftoxml)。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1931

2024.04.01

xml怎么变成word
xml怎么变成word

步骤:1. 导入 xml 文件;2. 选择 xml 结构;3. 映射 xml 元素到 word 元素;4. 生成 word 文档。提示:确保 xml 文件结构良好,并预览 word 文档以验证转换是否成功。想了解更多xml的相关内容,可以阅读本专题下面的文章。

2107

2024.08.01

xml是什么格式的文件
xml是什么格式的文件

xml是一种纯文本格式的文件。xml指的是可扩展标记语言,标准通用标记语言的子集,是一种用于标记电子文件使其具有结构性的标记语言。想了解更多相关的内容,可阅读本专题下面的相关文章。

1134

2024.11.28

scripterror怎么解决
scripterror怎么解决

scripterror的解决办法有检查语法、文件路径、检查网络连接、浏览器兼容性、使用try-catch语句、使用开发者工具进行调试、更新浏览器和JavaScript库或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

371

2023.10.18

500error怎么解决
500error怎么解决

500error的解决办法有检查服务器日志、检查代码、检查服务器配置、更新软件版本、重新启动服务、调试代码和寻求帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

340

2023.10.25

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

421

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

595

2023.08.10

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

1030

2026.02.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号