asp.net core 系列 14 错误处理

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 未找到。下面我们访问一个不存在的页面,默认页面显示如下:

asp.net core 系列 14 错误处理

下面提供状态代码页,使用状态代码页中间件,向 Startup.Configure 方法中添加。注意: 管道中请求处理中间件之前调用 UseStatusCodePages。

 //请求处理中间件之前调用 
app.UseStatusCodePages();
app.UseHttpsRedirection();
app.UseStaticFiles();
app.UseCookiePolicy();
app.UseMvc();

默认情况下,状态代码页中间件为常见状态代码(如 404)添加纯文本处理程序, 如下所示:

asp.net core 系列 14 错误处理

该中间件支持多种扩展方法。 一种方法采用 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()方法中进行业务处理。

asp.net core 系列 14 错误处理

asp.net core 系列 14 错误处理

参考文献

官方资料:asp.net core 错误处理

欢迎添加个人微信号:Like若所思。

欢迎关注我的公众号,不仅为你推荐最新的博文,还有更多惊喜和资源在等着你!一起学习共同进步!

asp.net core 系列 14 错误处理


分享到:


相關文章: