dotnet之美.

领略dotnet之美!

当未找到网页并且运用程序返回 404 缺点时,ASP.NET Core MVC 仅呈现通用浏览器缺点页面,如下图所示

aspnet拦截htmlASPNETCore同一处置404毛病都有哪些方法 JavaScript

这不是很优雅,是吗?我们平时看到的404页面一样平常是这样的

还有这样的

试了下京东,地址不存在的时候是会重定向到首页下面就来演示下ASP.NET Core中如何实现这种自定义的404页面处理。
新建项目 ASP.NET Core MVC(WebApi处理办法也一样)

新建好的项目直接运行的效果

随便输入一个地址 /test404

当未找到网页并且运用程序返回 404 缺点时,ASP.NET Core MVC 仅呈现通用浏览器缺点页面,如下图所示

办法一 FallbackEndpointRouteBuilderExtensions.MapFallback

这是个什么东西?

意思大概是说这是注册一个优先级最低的通配路由,来匹配所有路由,那就来试试效果吧。

// Program.csapp.UseAuthorization();app.MapControllerRoute( name: "default", pattern: "{controller=Home}/{action=Index}/{id?}");app.MapFallback(async (ctx) =>{ ctx.Response.Body.Write(Encoding.UTF8.GetBytes("404 from Fallback"));});app.Run();

试试效果如下

办法二 自定义通配路由

在HomeController添加一个Action如下

// HomeController.cs[Route("{url}", Order = 9999)]public IActionResult Page404(){ return View();}

添加对应的View页面如下

// Page404.cshtml@{ ViewData["Title"] = "404";}<div>404 for {url}</div>

效果图

上面两种办法虽然能够正常处理404缺点页,但是在程序内部抛出的404缺点却无法进行拦截

添加一个测试Action如下

[Route("/test404")]public IActionResult test404(){ // 一些业务处理,终极返回404 // return NotFound(); return StatusCode(404);}

你看,这种404场景,上述办法没能进行拦截处理。

办法三 自定义Middleware拦截

代码如下,关于Middleware如何利用这里不做先容

app.Use((context, next) =>{ var res = next(context); if (context.Response.StatusCode == 404) { context.Response.StatusCode = 200; context.Response.Body.Write(Encoding.UTF8.GetBytes("404 from Middleware")); } return res;});

把办法一和办法二的代码注释掉,运行测试效果如下不存在的地址

存在的地址,但是业务上返回404

办法四 UseStatusCodePagesWithReExecute

注释上个方法的代码

app.UseStatusCodePagesWithReExecute("/error/{0}");

// HomeController.cs[Route("test401")]public IActionResult test401(){ return StatusCode(401);}

public class ErrorController : Controller { [Route("error/404", Order = 9)] public IActionResult Error404() { ViewBag.code = 404; return View(); } [Route("error/{code:int}", Order = 1)] public IActionResult Error(int code) { ViewBag.code = code; switch (code) { case 404: ViewBag.msg = "对不起,要求的资源不存在。
"; break; case 401: ViewBag.msg = "对不起,您无权限访问此页面。
"; break; default: ViewBag.msg = "做事非常,请稍后重试!
"; break; } return View("Error404"); } }

// Error404.cshtml@{}<div>@ViewBag.code : @ViewBag.msg</div>

测试效果

完美!



办法五 web.config <customErrors> 节点中配置ASP.NET管道处理404缺点

这因此前framwork时期的iis配置办法,不推举利用了,也不进行测试了。

总结

个人认为办法三、四推举利用,四更加优雅,三是最灵巧的,还有没有其他办法进行拦截统一处理404缺点呢,欢迎补充。

本文源码已上传 github

https://github.com/SpringHgui/404test