【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
相关文章
|
3天前
|
Java 物联网 C#
C#/.NET/.NET Core学习路线集合,学习不迷路!
C#/.NET/.NET Core学习路线集合,学习不迷路!
|
7天前
|
Java 物联网 编译器
C#一分钟浅谈:.NET Core 与 .NET 5 区别
本文对比了 .NET Core 和 .NET 5,从历史背景、主要区别、常见问题及易错点等方面进行了详细分析。.NET Core 侧重跨平台支持和高性能,而 .NET 5 在此基础上统一了 .NET 生态系统,增加了更多新特性和优化。开发者可根据具体需求选择合适的版本。
25 7
|
3天前
|
人工智能 开发框架 前端开发
C#/.NET/.NET Core技术前沿周刊 | 第 12 期(2024年11.01-11.10)
C#/.NET/.NET Core技术前沿周刊 | 第 12 期(2024年11.01-11.10)
|
3天前
|
开发框架 网络协议 .NET
C#/.NET/.NET Core优秀项目和框架2024年10月简报
C#/.NET/.NET Core优秀项目和框架2024年10月简报
|
6天前
|
JSON 程序员 C#
使用 C# 比较两个对象是否相等的7个方法总结
比较对象是编程中的一项基本技能,在实际业务中经常碰到,比如在ERP系统中,企业的信息非常重要,每一次更新,都需要比较记录更新前后企业的信息,直接比较通常只能告诉我们它们是否指向同一个内存地址,那我们应该怎么办呢?分享 7 个方法给你!
|
8天前
|
C# UED SEO
C# 异步方法async / await任务超时处理
通过使用 `Task.WhenAny`和 `Task.Delay`方法,您可以在C#中有效地实现异步任务的超时处理机制。这种方法允许您在指定时间内等待任务完成,并在任务超时时采取适当的措施,如抛出异常或执行备用操作。希望本文提供的详细解释和代码示例能帮助您在实际项目中更好地处理异步任务超时问题,提升应用程序的可靠性和用户体验。
25 3
|
2天前
|
人工智能 开发框架 安全
C#/.NET/.NET Core技术前沿周刊 | 第 13 期(2024年11.11-11.17)
C#/.NET/.NET Core技术前沿周刊 | 第 13 期(2024年11.11-11.17)
|
3天前
|
网络协议 Unix Linux
精选2款C#/.NET开源且功能强大的网络通信框架
精选2款C#/.NET开源且功能强大的网络通信框架
|
3天前
|
程序员 C# 图形学
全面的C#/.NET自学入门指南
全面的C#/.NET自学入门指南
|
27天前
|
JSON C# 开发者
C#语言新特性深度剖析:提升你的.NET开发效率
【10月更文挑战第15天】C#语言凭借其强大的功能和易用性深受开发者喜爱。随着.NET平台的演进,C#不断引入新特性,如C# 7.0的模式匹配和C# 8.0的异步流,显著提升了开发效率和代码可维护性。本文将深入探讨这些新特性,助力开发者在.NET开发中更高效地利用它们。
32 1