<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
.Net Core 同 Asp.Net MVC一樣有幾種過濾器,這裡不再贅述每個過濾器的執行順序與作用。
在實際專案開發過程中,統一API返回值格式對前端或第三方呼叫將是非常必要的,在.NetCore中我們可以通過ActionFilterAttribute來進行統一返回值的封裝。
在封裝之前我們需要考慮下面幾個問題:
我目前的做法是,只對ObjectResult進行封裝,其他的型別:FileResult,ContentResult,EmptyResult,RedirectResult不予處理
既然是統一返回值,當然也要考慮介面異常的問題了
但是不是所有的異常我們都需要返回給前端的,我們可能需要自定義一個業務異常,業務異常可以在前端進行友好提示,系統異常完全沒必要丟擲給前端或第三方,且需要對系統異常進行紀錄檔記錄
專案結構:
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"); } }
下面是返回結果截圖:
上圖:存取/api/home和/api/home/redirect的結果
上圖:Action返回數位的結果
上圖:返回string集合的結果
上圖:輸出文字檔案的結果
上圖:返回ContentResult的結果
上圖:系統異常的結果,輸出狀態碼為500
上圖:丟擲業務異常的結果,輸出狀態碼200
不知道如何上傳ZIP包,範例程式碼專案已經放到Gitee上了,後面有時間也會寫點簡單的例子
地址:https://gitee.com/tang3402/net-core-samples.git
到此這篇關於.NetCore Web Api 利用ActionFilterAttribute統一介面返回值格式的文章就介紹到這了,更多相關.NetCore Web Api 統一介面返回值格式內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45