.net core 自定义规范响应的中间件

在本文中,我们将介绍如何使用 .NET Core 中的中间件来自定义规范响应,以便在 API 调用时返回统一的格式和错误信息。中间件是一种可以在请求和响应管道中执行逻辑的软件组件,它可以对请求或响应进行修改、拦截或处理。我们将使用一个简单的示例来演示如何创建和使用自定义规范响应的中间件。

首先,我们需要创建一个类来表示规范响应的格式,这个类可以包含以下属性:

  • Code:响应的状态码,例如 200 表示成功,400 表示客户端错误,500 表示服务器错误等。
  • Message:响应的消息,例如 "OK" 表示成功,"Bad Request" 表示客户端错误,"Internal Server Error" 表示服务器错误等。
  • Data:响应的数据,可以是任意类型的对象,例如用户信息、产品列表、订单详情等。

这个类的代码如下:

public class ApiResponse
{
    public bool Success { get; set; }
    public string Message { get; set; }
    public object Data { get; set; }

    public ApiResponse(bool success, string message, object data)
    {
        Success = success;
        Message = message;
        Data = data;
    }

    public ApiResponse(bool success, string message)
        : this(success, message, null)
    {
    }

    public ApiResponse(bool success)
        : this(success, null, null)
    {
    }
}

中间件

接下来,我们需要创建一个中间件类来实现自定义规范响应的逻辑,这个类需要有以下特点:

  • 接收一个 RequestDelegate 类型的参数,表示下一个中间件或终端处理程序。
  • 实现一个 InvokeAsync 方法,接收一个 HttpContext 类型的参数,表示当前请求的上下文。
  • InvokeAsync 方法中,使用 await next(context) 来调用下一个中间件或终端处理程序,并获取其返回的响应。
  • InvokeAsync 方法中,根据响应的状态码和内容来构造一个 ApiResponse对象,并将其序列化为 JSON 格式。
  • InvokeAsync 方法中,修改响应的内容类型为 application/json,并将 JSON 格式的 ApiResponse写入到响应体中。
  • GetStatusCodeMessage()根据响应状态给出信息
  • GetResponseData()获取其返回的响应

CustomResponseMiddleware

public class CustomResponseMiddleware
{
    private readonly RequestDelegate _next;

    public CustomResponseMiddleware(RequestDelegate next)
    {
        _next = next;
    }

    public async Task InvokeAsync(HttpContext context)
    {
        var originalBodyStream = context.Response.Body;

        using (var responseBody = new MemoryStream())
        {
            context.Response.Body = responseBody;

            await _next(context);

            if (context.Response.StatusCode >= 400 && context.Response.StatusCode <= 599)
            {
                context.Response.ContentType = "application/json";

                var response = new ApiResponse
                {
                    Success = false,
                    Message = GetStatusCodeMessage(context.Response.StatusCode),
                    Data = await GetResponseData(context.Response)
                };

                var jsonResponse = JsonConvert.SerializeObject(response);
                await context.Response.WriteAsync(jsonResponse, Encoding.UTF8);
            }
            else
            {
                context.Response.ContentType = "application/json";

                var response = new ApiResponse
                {
                    Success = true,
                    Message = GetStatusCodeMessage(context.Response.StatusCode),
                    Data = await GetResponseData(context.Response)
                };

                var jsonResponse = JsonConvert.SerializeObject(response);
                await context.Response.WriteAsync(jsonResponse, Encoding.UTF8);
            }

            await responseBody.CopyToAsync(originalBodyStream);
        }
    }
}

GetStatusCodeMessage()

 private static string GetStatusCodeMessage(int statusCode)
    {
        switch (statusCode)
        {
            case 200:
                return "OK";
            case 201:
                return "Created";
            case 204:
                return "No Content";
            case 400:
                return "Bad Request";
            case 401:
                return "Unauthorized";
            case 403:
                return "Forbidden";
            case 404:
                return "Not Found";
            case 500:
                return "Internal Server Error";
            default:
                return "Unknown Status Code";
        }
    }

GetResponseData()

private async Task<object> GetResponseData(HttpResponse response)
    {
        var body = await new StreamReader(response.Body).ReadToEndAsync();
        response.Body.Seek(0, SeekOrigin.Begin);

        try
        {
            return JsonConvert.DeserializeObject(body);
        }
        catch (JsonReaderException)
        {
            return new { Message = body };
        }
    }

在上面的示例中,我们创建了一个名为 CustomResponseMiddleware 的中间件。该中间件拦截每个响应,并根据需要修改响应格式。具体来说,如果响应的状态码为 4xx 或5xx,则中间件将返回一个包含错误消息和数据的 ApiResponse 对象;否则,中间件将返回一个包含成功消息和数据的 ApiResponse 对象。

常用类

定义常用的类可以帮助我们标准化 ASP.NET Core 应用程序中的响应格式,提高代码重用性,并使前端更加轻松地处理所有响应。

除了 ApiResponse 类之外,还可以定义其他常用类,如 ApiError 类、ApiResponse 泛型类等,以满足不同的需求。例如,ApiError 类可以用于标准化应用程序中的错误响应格式,ApiResponse 泛型类可以用于在响应中包含更具体的数据类型。

下面是 ApiError 类的示例代码:

public class ApiError
{
    public int StatusCode { get; set; }
    public string Message { get; set; }

    public override string ToString()
    {
        return JsonConvert.SerializeObject(this);
    }
}

ApiError 类包含两个属性:StatusCodeMessageStatusCode 属性指示错误的状态码,Message 属性包含有关错误的消息。

使用 ApiError 类可以帮助我们标准化应用程序中的错误响应格式。例如,在某些情况下,我们可能需要返回一个包含单个错误消息的响应,而在其他情况下,我们可能需要返回一个包含多个错误消息的响应。通过使用 ApiError 类,我们可以在应用程序中统一处理这些情况,并返回一个标准的错误响应格式。

结论

通过使用 ASP.NET Core 中间件和常用类,我们可以自定义 ASP.NET Core 应用程序中的响应格式,并标准化应用程序中的响应格式。这可以提高代码重用性,并使前端更加轻松地处理所有响应。在开发 ASP.NET Core 应用程序时,我们应该始终考虑使用中间件和常用类来提高代码的可读性、可维护性和可重用性。

原文链接:https://www.cnblogs.com/ke210/p/17298562.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:.net core 自定义规范响应的中间件 - Python技术站

(0)
上一篇 2023年4月18日
下一篇 2023年4月18日

相关文章

  • asp.net(c#)ref,out ,params的区别

    那么让我们来详细讲解一下“asp.net(c#)ref,out ,params的区别”的完整攻略吧。 1. ref参数 ref参数用于将变量的引用传递给函数,这意味着如果在函数内修改了该变量,那么同样会修改函数外的原始变量。使用ref参数时,需要确保变量已经被初始化。 示例代码: void AddOne(ref int x) { x += 1; } int …

    C# 2023年6月7日
    00
  • Fastjson 常用API介绍及下载地址(推荐)

    Fastjson 常用 API 介绍及下载地址(推荐) 介绍 Fastjson是一个Java语言编写的高性能JSON处理器,它可以将Java对象转换为JSON,也可以将JSON转换为Java对象,并且速度非常快,被广泛应用于各种Java Web应用中。Fastjson的优势在于比其他的json处理器更快。 下载地址 Fastjson的下载地址:https:/…

    C# 2023年5月31日
    00
  • C#实现在应用程序间发送消息的方法示例

    以下是C#实现在应用程序间发送消息的方法示例的完整攻略: 1. 介绍 在日常的软件开发中,我们常常会遇到在应用程序之间进行数据交互的场景,例如不同的窗口之间进行通信、不同的进程之间进行消息传递等。而在C#中,要实现应用程序间的消息传递,可以通过使用Windows API来实现消息队列或是共享内存两种方式,也可以使用.NET Framework提供的一些类库来…

    C# 2023年6月7日
    00
  • 大白话讲解C# 中的委托

    大白话讲解C# 中的委托 什么是委托? 在C#中,委托是一种类型,它可以封装一个或一组方法,供其他代码调用。简单来说,它就是函数指针的一种类型安全实现。 委托的定义和使用 可以使用 delegate 关键字定义委托,如下所示: public delegate void DelegateType(int param); 上面这段代码中,我们定义了一个名为 De…

    C# 2023年6月7日
    00
  • C#中把Json数据转为DataTable

    让我们来介绍如何在C#中将Json数据转换为DataTable。在此之前需要先引入Newtonsoft.Json这个第三方库,可以通过NuGet安装。以下是详细步骤: 1. 读取Json数据 首先我们需要读取Json数据。可以从文件或Web API获取Json数据。以下是从文件读取Json数据的示例: using System.IO; string path…

    C# 2023年5月31日
    00
  • C#表达式树讲解

    C# 表达式树讲解 在 C# 中,表达式树(Expression Tree)是一个类似于代码的树形数据结构,可以表示出一个语法树、一个 lambda 表达式、一个 LINQ 查询等等。 表达式树是由表达式节点构成的,每个节点代表一个表达式或语句。 表达式树的语法 表达式树和 C# 中的 lambda 表达式比较类似,都是由参数、箭头符号和表达式组成。例如以下…

    C# 2023年6月1日
    00
  • 详解使用DotNet CLI创建自定义的WPF项目模板

    我来为你详细讲解使用DotNet CLI创建自定义的WPF项目模板的完整攻略。以下是具体步骤: 步骤一:创建WPF项目 首先,我们需要创建一个WPF项目。可以在Visual Studio中创建或者使用以下命令在终端中创建: dotnet new wpf -n <项目名称> 这样我们就创建了一个名为<项目名称>的WPF项目。 步骤二:创…

    C# 2023年6月7日
    00
  • c#线程Thread示例

    好的。我们先来讲解一下c#线程的概念。 c#线程是指在一个程序中独立运行的执行路径。可以同时运行多个线程,每个线程都是独立运行的,互不干扰。它可以帮助我们完成一些比较复杂的并发操作,例如同时下载多个文件、多线程爬虫、多线程计算等。 下面我们来看一些示例。 示例一:创建线程 在c#中,我们可以通过Thread类创建线程。下面是一个简单的示例: using Sy…

    C# 2023年5月15日
    00
合作推广
合作推广
分享本页
返回顶部