【C#】.net core2.1,通过扩展状态代码页方法对404页面进行全局捕抓并响应信息

简介: 在开发一个网站项目时,除了异常过滤功能模块,还需要有针对404不存在的api接口和页面处理功能 本篇文章就来讲讲,如何自定义全局请求状态类来统一处理
作者:小5聊基础
简介:一只喜欢全栈方向的程序员,欢迎咨询,尽绵薄之力答疑解惑
编程原则:Write Less Do More

在上一篇文章中讲解了如何全局统一处理异常,可跳转查看<br/>
【C#】.net core2.1,自定义全局类对API接口和视图页面产生的异常统一处理

  • 流程图

image.png

【基本信息】

1)操作系统:windows11 <br/>
2)开发工具:VS 2017 <br/>
3)开发语言:C# <br/>
4)开发框架:.net core 2.1 <br/>
5)关键类:this IApplicationBuilder <br/>

【创建状态码页面扩展类】

技术日新月异,同一个功能,版本肯定会在不停更新升级,除非已经弃用,因此,需要针对版本进行使用,否则可能会因为版本不用导致报错<br/>
1)定义个静态类
自定义一个静态类即可,类命无需引用 <br/>
static UseStatusCodePagesExtension

2)设置类下面的一个自定义扩展方法 <br/>
public static void UseStatusCodePagesEx(this IApplicationBuilder app)<br/>
关键是this扩展方法参数,IApplicationBuilder app

3)this关键放在方法参数变量前面,表示对当前参数变量的一个扩展 <br/>
比如:MyTest(this string test) <br/>
那么就类型就可以通过点的方法调用扩展方法,"Hello".MyTest() <br/>

4)直接调用接口本身的方法,通过正则表达式的方式获取关键值 <br/>
app.UseStatusCodePages(context=>{ })

5)请求协议 <br/>
可以根据http和https进行请求协议判断,也许在项目上需要对这两个请求协议做一个区别判断
context.HttpContext.Request.IsHttps

6)请求地址 <br/>
string url = http + context.HttpContext.Request.Host + context.HttpContext.Request.Path;

image.png

7)类完整代码


using Microsoft.AspNetCore.Builder;
using Microsoft.AspNetCore.Http;
using Microsoft.AspNetCore.Mvc;
using Newtonsoft.Json;
using System;
using System.Text;
using System.Threading.Tasks;

namespace web.Class
{
    /// <summary>
    /// 异常处理 - 不存在的请求(Get/Post)
    /// </summary>
    public static class UseStatusCodePagesExtension
    {
        /// <summary>
        /// 静态方法
        /// </summary>
        /// <param name="app">要进行扩展的类型</param>
        public static void UseStatusCodePagesEx(this IApplicationBuilder app)
        {
            app.UseStatusCodePages(context =>
            {
                /*
                    //添加带有指定处理程序的StatusCodePages中间件,该处理程序用于检查
                    //状态代码介于400和599之间且没有正文的响应。
                 */

                StringBuilder errorMessage = new StringBuilder();
                var method = context.HttpContext.Request.Method;
                if (string.IsNullOrEmpty(method))
                {
                    //return Task.CompletedTask;
                }

                string http = (context.HttpContext.Request.IsHttps ? "https://" : "http://");
                string url = http + context.HttpContext.Request.Host + context.HttpContext.Request.Path;
                int code = context.HttpContext.Response.StatusCode;

                if (method.ToLower() == "Get".ToLower())
                {
                    errorMessage.Clear();
                    errorMessage.Append($"<meta name=\"viewport\" content=\"width=device-width, height=device-height, initial-scale=1.0, minimum-scale=1.0, maximum-scale=1.0, user-scalable=no\">");
                    errorMessage.Append($"<h1>访问的资源不存在</h1>");
                    errorMessage.Append($"<p>URL:{url}</p>");
                    errorMessage.Append($"<p>StatusCode:{code}</p>");
                    errorMessage.Append($"<p>GET</p>");

                    context.HttpContext.Response.ContentType = "text/html;charset=utf-8";
                    context.HttpContext.Response.StatusCode = 200;

                    using (var responseStream = context.HttpContext.Response.Body)
                    {
                        responseStream.Write(Encoding.Default.GetBytes(errorMessage.ToString()));
                    }
                }
                else if (method.ToLower() == "POST".ToLower())
                {
                    errorMessage.Clear();
                    errorMessage.Append($"访问的资源不存在,");
                    errorMessage.Append($"URL:{ url},");
                    errorMessage.Append($"StatusCode:{code},");
                    errorMessage.Append($"POST");

                    var result = new
                    {
                        message = errorMessage.ToString(),
                        code = 404
                    };

                    context.HttpContext.Response.ContentType = "application/json;charset=utf-8";
                    context.HttpContext.Response.StatusCode = 200;
                    using (var responseStream = context.HttpContext.Response.Body)
                    {
                        responseStream.Write(Encoding.Default.GetBytes(JsonConvert.SerializeObject(result)));
                    }
                }
                else
                {
                    errorMessage.Clear();
                    errorMessage.Append($"访问的资源不存在,");
                    errorMessage.Append($"URL:{ url},");
                    errorMessage.Append($"StatusCode:{code}");

                    var result = new {
                        message = errorMessage.ToString(),
                        code = 404
                    };

                    context.HttpContext.Response.ContentType = "application/json;charset=utf-8";
                    context.HttpContext.Response.StatusCode = 200;
                    using (var responseStream = context.HttpContext.Response.Body)
                    {
                        responseStream.Write(Encoding.Default.GetBytes(JsonConvert.SerializeObject(result)));
                    }
                }

                //输出错误日志到txt以及添加一条日志记录(使用了一次数据库链接)
                if (true)
                {
                }

                return Task.CompletedTask;
            });
        }
    }
}

【Startup启动类设置】

由于是对接口IApplicationBuilder进行扩展,所以只需要在Configure配置方法里进行调用即可
1)需要注意代码的顺序

//调用UseStatusCodePages中间件要在例如静态文件中间件和 MVC中间件等中间件前面调用
app.UseStatusCodePagesEx(); //自定义异常中间件

//开启静态文件访问 - wwwroot
相关文章
|
17天前
|
开发框架 .NET C#
C#|.net core 基础 - 删除字符串最后一个字符的七大类N种实现方式
【10月更文挑战第9天】在 C#/.NET Core 中,有多种方法可以删除字符串的最后一个字符,包括使用 `Substring` 方法、`Remove` 方法、`ToCharArray` 与 `Array.Copy`、`StringBuilder`、正则表达式、循环遍历字符数组以及使用 LINQ 的 `SkipLast` 方法。
|
1月前
|
开发框架 .NET 程序员
C# 去掉字符串最后一个字符的 4 种方法
在实际业务中,我们经常会遇到在循环中拼接字符串的场景,循环结束之后拼接得到的字符串的最后一个字符往往需要去掉,看看 C# 提供了哪4种方法可以高效去掉字符串的最后一个字符
164 0
|
16天前
|
编译器 C#
C#多态概述:通过继承实现的不同对象调用相同的方法,表现出不同的行为
C#多态概述:通过继承实现的不同对象调用相同的方法,表现出不同的行为
111 65
|
2天前
|
JSON C# 开发者
C#语言新特性深度剖析:提升你的.NET开发效率
【10月更文挑战第15天】C#语言凭借其强大的功能和易用性深受开发者喜爱。随着.NET平台的演进,C#不断引入新特性,如C# 7.0的模式匹配和C# 8.0的异步流,显著提升了开发效率和代码可维护性。本文将深入探讨这些新特性,助力开发者在.NET开发中更高效地利用它们。
9 1
|
13天前
|
存储 消息中间件 NoSQL
Redis 入门 - C#.NET Core客户端库六种选择
Redis 入门 - C#.NET Core客户端库六种选择
48 8
|
8天前
|
人工智能 开发框架 C#
C#/.NET/.NET Core技术前沿周刊 | 第 6 期(2024年9.16-9.22)
C#/.NET/.NET Core技术前沿周刊 | 第 6 期(2024年9.16-9.22)
|
8天前
|
人工智能 开发框架 Cloud Native
C#/.NET/.NET Core技术前沿周刊 | 第 9 期(2024年10.07-10.13)
C#/.NET/.NET Core技术前沿周刊 | 第 9 期(2024年10.07-10.13)
|
8天前
|
开发框架 前端开发 API
C#/.NET/.NET Core优秀项目和框架2024年9月简报
C#/.NET/.NET Core优秀项目和框架2024年9月简报
|
8天前
|
开发框架 NoSQL MongoDB
C#/.NET/.NET Core开发实战教程集合
C#/.NET/.NET Core开发实战教程集合
|
14天前
|
存储 C#
【C#】大批量判断文件是否存在的两种方法效率对比
【C#】大批量判断文件是否存在的两种方法效率对比
23 1