中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

.NetCore?Web?Api怎么用ActionFilterAttribute統一接口返回值格式

發布時間:2022-03-10 16:29:52 來源:億速云 閱讀:366 作者:iii 欄目:開發技術

本文小編為大家詳細介紹“.NetCore Web Api怎么用ActionFilterAttribute統一接口返回值格式”,內容詳細,步驟清晰,細節處理妥當,希望這篇“.NetCore Web Api怎么用ActionFilterAttribute統一接口返回值格式”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來學習新知識吧。

.Net Core 同 Asp.Net MVC一樣有幾種過濾器,這里不再贅述每個過濾器的執行順序與作用。

在實際項目開發過程中,統一API返回值格式對前端或第三方調用將是非常必要的,在.NetCore中我們可以通過ActionFilterAttribute來進行統一返回值的封裝。

在封裝之前我們需要考慮下面幾個問題:

1,需要對哪些結果進行封裝

我目前的做法是,只對ObjectResult進行封裝,其他的類型:FileResult,ContentResult,EmptyResult,RedirectResult不予處理

2,對異常錯誤的封裝

既然是統一返回值,當然也要考慮接口異常的問題了

但是不是所有的異常我們都需要返回給前端的,我們可能需要自定義一個業務異常,業務異常可以在前端進行友好提示,系統異常完全沒必要拋出給前端或第三方,且需要對系統異常進行日志記錄

項目結構:

.NetCore?Web?Api怎么用ActionFilterAttribute統一接口返回值格式

Exceptions:自定義業務異常

Filters:自定義過濾器(統一結果封裝,全局異常)

Models:統一結果實體

部分代碼:

using System;
 
namespace NetCoreCommonResult.Exceptions
{
    /// <summary>
    /// 自定義業務異常,可以由前端拋出友好的提示
    /// </summary>
    public class BizException:Exception
    {
        public BizException()
        {
        }
        public BizException(string message):base(message)
        public BizException(string message, Exception ex) : base(message, ex)
    }
}
using Microsoft.AspNetCore.Mvc;
using Microsoft.AspNetCore.Mvc.Filters;
 
namespace NetCoreCommonResult.Filters
{
    public class CommonResultFilterAttribute : ActionFilterAttribute
    {
        public override void OnResultExecuting(ResultExecutingContext context)
        {
            if (context.Result is ObjectResult objRst)
            {
                if (objRst.Value is Models.ApiResult)
                    return;
                context.Result = new ObjectResult(new Models.ApiResult
                {
                    Success = true,
                    Message = string.Empty,
                    Data = objRst.Value
                });
            }
        }
    }
}
using Microsoft.AspNetCore.Mvc;
using Microsoft.AspNetCore.Mvc.Filters;
using Microsoft.Extensions.Logging;
 
namespace NetCoreCommonResult.Filters
{
    public class GlobalExceptionFilterAttribute : ExceptionFilterAttribute
    {
        private readonly ILogger<GlobalExceptionFilterAttribute> _logger;
        public GlobalExceptionFilterAttribute(ILogger<GlobalExceptionFilterAttribute> logger)
        {
            _logger = logger;
        }
        public override void OnException(ExceptionContext context)
        {
            context.ExceptionHandled = true;
            var isBizExp = context.Exception is Exceptions.BizException;
            context.Result = new ObjectResult(new Models.ApiResult
            {
                Success = false,
                Message = context.Exception.Message
            });
            //非業務異常記錄errorLog,返回500狀態碼,前端通過捕獲500狀態碼進行友好提示
            if (isBizExp == false)
            {
                _logger.LogError(context.Exception, context.Exception.Message);
                context.HttpContext.Response.StatusCode = 500;
            }
            base.OnException(context);
        }
    }
}

Startup.cs

using Microsoft.AspNetCore.Builder;
using Microsoft.AspNetCore.Hosting;
using Microsoft.Extensions.Configuration;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Hosting;
 
namespace NetCoreCommonResult
{
    public class Startup
    {
        public Startup(IConfiguration configuration)
        {
            Configuration = configuration;
        }
        public IConfiguration Configuration { get; }
        // This method gets called by the runtime. Use this method to add services to the container.
        public void ConfigureServices(IServiceCollection services)
            services.AddLogging();
            services.AddControllers(ops =>
            {
                //添加過濾器
                ops.Filters.Add(new Filters.CommonResultFilterAttribute());
                //GlobalExceptionFilterAttribute構造中注入其他服務,需要通過ServiceFilter添加
                ops.Filters.Add(new Microsoft.AspNetCore.Mvc.ServiceFilterAttribute(typeof(Filters.GlobalExceptionFilterAttribute)));
            });
            //注冊GlobalExceptionFilterAttribute
            services.AddScoped<Filters.GlobalExceptionFilterAttribute>();
        // This method gets called by the runtime. Use this method to configure the HTTP request pipeline.
        public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
            if (env.IsDevelopment())
                app.UseDeveloperExceptionPage();
            }
            else
                app.UseExceptionHandler("/Error");
            app.UseStaticFiles();
            app.UseRouting();
            app.UseAuthorization();
            app.UseEndpoints(endpoints =>
                endpoints.MapControllers();
    }
}

最后新建一個Controller然后寫上幾個不同返回值的的Action

using Microsoft.AspNetCore.Mvc;
using System;
using System.Collections.Generic;
using System.Text;
using System.Threading.Tasks;
 
namespace NetCoreCommonResult.Controllers
{
    [Route("api/[controller]")]
    [ApiController]
    public class HomeController : ControllerBase
    {
        /// <summary>
        /// string
        /// </summary>
        /// <returns></returns>
        [HttpGet]
        public string Index() => "Welecome to .NetCore";
        /// 跳轉,不處理
        [HttpGet("redirect")]
        public ActionResult Redirect() => RedirectToAction("Index");
        ///
        [HttpGet("num")]
        public int Num() => 10;
        /// 異步
        [HttpGet("async")]
        public Task<IEnumerable<string>> TaskString() =>Task.FromResult<IEnumerable<string>>(new[] { "A","B","C"});
        /// 文件輸出,不處理
        [HttpGet("file")]
        public ActionResult GetFile() => File(Encoding.UTF8.GetBytes("File String"), "text/plain");
        /// 空返回值,不處理
        [HttpGet("empty")]
        public ActionResult Empty() => Empty();
        /// contentResult 不處理
        [HttpGet("content")]
        public ActionResult Content() => Content("this is content");
        /// 異常,返回500錯誤
        [HttpGet("exception")]
        public ActionResult GetException() => throw new InvalidOperationException("invalid");
        /// 自定義異常,返回200
        [HttpGet("bizException")]
        public ActionResult GetBizException() => throw new Exceptions.BizException("bizException");
    }
}

下面是返回結果截圖:

.NetCore?Web?Api怎么用ActionFilterAttribute統一接口返回值格式

上圖:訪問/api/home和/api/home/redirect的結果

.NetCore?Web?Api怎么用ActionFilterAttribute統一接口返回值格式

上圖:Action返回數字的結果

.NetCore?Web?Api怎么用ActionFilterAttribute統一接口返回值格式

上圖:返回string集合的結果

.NetCore?Web?Api怎么用ActionFilterAttribute統一接口返回值格式

上圖:輸出文本文件的結果

.NetCore?Web?Api怎么用ActionFilterAttribute統一接口返回值格式

上圖:返回ContentResult的結果

.NetCore?Web?Api怎么用ActionFilterAttribute統一接口返回值格式

上圖:系統異常的結果,輸出狀態碼為500

.NetCore?Web?Api怎么用ActionFilterAttribute統一接口返回值格式

上圖:拋出業務異常的結果,輸出狀態碼200

讀到這里,這篇“.NetCore Web Api怎么用ActionFilterAttribute統一接口返回值格式”文章已經介紹完畢,想要掌握這篇文章的知識點還需要大家自己動手實踐使用過才能領會,如果想了解更多相關內容的文章,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

舞阳县| 额敏县| 鹤庆县| 鲁甸县| 乌什县| 婺源县| 营口市| 皮山县| 扬中市| 台江县| 介休市| 射阳县| 即墨市| 南漳县| 临城县| 闸北区| 长宁区| 南京市| 怀仁县| 牙克石市| 平山县| 许昌市| 三原县| 新田县| 广宁县| 康平县| 南涧| 潼南县| 华安县| 疏附县| 卢氏县| 五家渠市| 漯河市| 湟中县| 含山县| 澜沧| 新巴尔虎左旗| 伊春市| 叙永县| 宣威市| 宜兰县|