asp.net core 系列 14 错误处理
一.概述
本文介绍处理 asp.net core 应用中常见错误的一些方法。主要是关于:开发环境异常页;非开发环境配置自定义异常处理页;配置状态代码页(没有正文响应,http状态400~599的)。
1.1 开发环境异常页
要将应用配置为显示有关异常的详细信息的页面,请使用开发环境异常页。要环境设置为 development,具体查看:asp.net core系列9环境。下面向 startup.configure 方法添加代码行:
if (env.isdevelopment()) { //注意: 调用该方法,要放在对其捕获异常的任何中间件前面,中间件格式use{ xxx }(),如usemvc(); app.usedeveloperexceptionpage(); }
1.2 配置自定义异常处理页
配置自定义异常处理页,用于非 development
环境下,下面是razor项目中的异常处理页代码(pages下error.cshtml页面)。
if (env.isdevelopment()) { app.usedeveloperexceptionpage(); } else { app.useexceptionhandler("/error"); }
在 mvc 应用中,不要使用 http 方法特性(如 httpget
)修饰错误处理程序操作方法。 显式谓词可阻止某些请求访问方法。 允许匿名访问方法,以便未经身份验证的用户能够接收错误视图。
//mvc中,homecontroller中的error, 添加[allowanonymous] [allowanonymous] [responsecache(duration = 0, location = responsecachelocation.none, nostore = true)] public iactionresult error() { return view(new errorviewmodel { requestid = activity.current?.id ?? httpcontext.traceidentifier }); }
1.3配置状态代码页
默认情况下,应用不会为 http 状态代码提供丰富状态代码页,例如 404 未找到。下面我们访问一个不存在的页面,默认页面显示如下:
下面提供状态代码页,使用状态代码页中间件,向 startup.configure
方法中添加。注意: 管道中请求处理中间件之前调用 usestatuscodepages。
//请求处理中间件之前调用 app.usestatuscodepages(); app.usehttpsredirection(); app.usestaticfiles(); app.usecookiepolicy(); app.usemvc();
默认情况下,状态代码页中间件为常见状态代码(如 404)添加纯文本处理程序, 如下所示:
该中间件支持多种扩展方法。 一种方法采用 lambda 表达式:
//自定义页面的输出类型和文字信息及状态码,用于处理程序,检查状态代码在400~599之间且没有正文的响应 app.usestatuscodepages(async context => { context.httpcontext.response.contenttype = "text/plain"; await context.httpcontext.response.writeasync( "status code page, status code: " + context.httpcontext.response.statuscode); });
usestatuscodepages
重载需要使用内容类型和格式字符串:
app.usestatuscodepages("text/plain", "status code page, status code: {0}");
1.4 usestatuscodepageswithredirects重定向
该中间件作用是: (1) 向客户端发送“302 和状态码。(2)将客户端重定向到 url 模板中的位置。
//当没有正文的响应时,重定向到指定页面,{0}点位符表示请求出错的http的状态码 app.usestatuscodepageswithredirects("/error/{0}"); //请求处理中间件之前调用 // app.usestatuscodepages();
下面是在razor项目中,当访问一个不存在的页面时http://localhost:60397/page/missingpage,地址重定向到error页并显示出错的状态码,必要时还可以在error页的onget()方法中进行业务处理。
参考文献
官方资料:
上一篇: Java 的标识接口作用
下一篇: 豪华自助餐
推荐阅读
-
asp.net core系列 72 Exceptionless使用介绍
-
解读ASP.NET 5 & MVC6系列教程(14):View Component
-
ASP.NET Core MVC/WebApi基础系列1
-
ASP.NET Core MVC/WebApi基础系列2
-
asp.net core系列之模型绑定和验证方法
-
asp.net core 系列之并发冲突的深入理解
-
ASP.NET Core MVC/WebApi基础系列2
-
(14)ASP.NET Core 中的日志记录
-
解读ASP.NET 5 & MVC6系列教程(14):View Component
-
ASP.NET CORE系列【七】分析NetCore启动原理