最近搭项目框架,为了便于接口返回值统一规范,做了一些配置,使得无论接口方法返回值是什么类型,都统一做了拦截,具体实现方式为:

首先需要几个过滤类:异常处理返回类,正常调用统一返回类,忽略返回格式类,

对应类代码如下:

异常处理返回类

  1. using System;
  2. using System.Linq;
  3. using Microsoft.AspNetCore.Mvc;
  4. using Microsoft.AspNetCore.Mvc.Controllers;
  5. using Microsoft.AspNetCore.Mvc.Filters;
  6. namespace S2_Xxxx_XxxNetApi
  7. {
  8. /// <summary>
  9. /// Api action统一处理过滤器
  10. /// 处理正常返回值
  11. /// </summary>
  12. public class ApiResultFilterAttribute : Attribute, IActionFilter
  13. {
  14. /// <summary>
  15. /// 执行方法体之后
  16. /// 返回结果为JsonResult的请求进行Result包装
  17. /// </summary>
  18. /// <param name="context"></param>
  19. public void OnActionExecuted(ActionExecutedContext context)
  20. {
  21. //特殊处理:对有ApiIgnoreAttribute标签的,不进行返回结果包装,原样输出
  22. var controllerActionDescriptor = context.ActionDescriptor as ControllerActionDescriptor;
  23. if (controllerActionDescriptor != null)
  24. {
  25. var isDefined = controllerActionDescriptor.EndpointMetadata.Any(a => a.GetType().Equals(typeof(ApiIgnoreAttribute)));
  26. if (isDefined)
  27. {
  28. return;
  29. }
  30. }
  31. // 返回结果为JsonResult的请求进行Result包装
  32. if (context.Result != null)
  33. {
  34. if (context.Result is ObjectResult)
  35. {
  36. var result = context.Result as ObjectResult;
  37. context.Result = new JsonResult(new { code = 200, msg = "success", data = result.Value });
  38. }
  39. else if (context.Result is EmptyResult)
  40. {
  41. context.Result = new JsonResult(new { code = 200, msg = "success", data = new { } });
  42. }
  43. else if (context.Result is ContentResult)
  44. {
  45. var result = context.Result as ContentResult;
  46. context.Result = new JsonResult(new { code = result.StatusCode, msg = result.Content });
  47. }
  48. else
  49. {
  50. throw new Exception($"未经处理的Result类型:{ context.Result.GetType().Name}");
  51. }
  52. }
  53. }
  54. /// <summary>
  55. /// 执行方法体之前
  56. /// </summary>
  57. /// <param name="context"></param>
  58. public void OnActionExecuting(ActionExecutingContext context)
  59. {
  60. //不做修改
  61. }
  62. }
  63. }

正常调用统一返回类

  1. using System;
  2. using System.Linq;
  3. using Microsoft.AspNetCore.Mvc;
  4. using Microsoft.AspNetCore.Mvc.Controllers;
  5. using Microsoft.AspNetCore.Mvc.Filters;
  6. namespace S2_Xxxx_XxxNetApi
  7. {
  8. /// <summary>
  9. /// Api action统一处理过滤器
  10. /// 处理正常返回值
  11. /// </summary>
  12. public class ApiResultFilterAttribute : Attribute, IActionFilter
  13. {
  14. /// <summary>
  15. /// 执行方法体之后
  16. /// 返回结果为JsonResult的请求进行Result包装
  17. /// </summary>
  18. /// <param name="context"></param>
  19. public void OnActionExecuted(ActionExecutedContext context)
  20. {
  21. //特殊处理:对有ApiIgnoreAttribute标签的,不进行返回结果包装,原样输出
  22. var controllerActionDescriptor = context.ActionDescriptor as ControllerActionDescriptor;
  23. if (controllerActionDescriptor != null)
  24. {
  25. var isDefined = controllerActionDescriptor.EndpointMetadata.Any(a => a.GetType().Equals(typeof(ApiIgnoreAttribute)));
  26. if (isDefined)
  27. {
  28. return;
  29. }
  30. }
  31. // 返回结果为JsonResult的请求进行Result包装
  32. if (context.Result != null)
  33. {
  34. if (context.Result is ObjectResult)
  35. {
  36. var result = context.Result as ObjectResult;
  37. context.Result = new JsonResult(new { code = 200, msg = "success", data = result.Value });
  38. }
  39. else if (context.Result is EmptyResult)
  40. {
  41. context.Result = new JsonResult(new { code = 200, msg = "success", data = new { } });
  42. }
  43. else if (context.Result is ContentResult)
  44. {
  45. var result = context.Result as ContentResult;
  46. context.Result = new JsonResult(new { code = result.StatusCode, msg = result.Content });
  47. }
  48. else
  49. {
  50. throw new Exception($"未经处理的Result类型:{ context.Result.GetType().Name}");
  51. }
  52. }
  53. }
  54. /// <summary>
  55. /// 执行方法体之前
  56. /// </summary>
  57. /// <param name="context"></param>
  58. public void OnActionExecuting(ActionExecutingContext context)
  59. {
  60. //不做修改
  61. }
  62. }
  63. }

忽略返回格式类(这个类根据实际需求调整不需要拦截返回的类型)

  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Threading.Tasks;
  5. namespace S2_Xxxx_XxxNetApi
  6. {
  7. /// <summary>
  8. /// 使用该标签,对结果原样输出,不做包装
  9. /// </summary>
  10. public class ApiIgnoreAttribute : Attribute
  11. {
  12. }
  13. }

然后在程序启动类注入相关方法

  1. public void ConfigureServices(IServiceCollection services)
  2. {
  3. //注册过滤器
  4. services.AddSingleton<ApiResultFilterAttribute>();
  5. services.AddSingleton<ApiExceptionFilterAttribute>();
  6. services.AddMvc(
  7. config =>
  8. {
  9. config.EnableEndpointRouting = false;
  10. config.Filters.AddService(typeof(ApiResultFilterAttribute));
  11. config.Filters.AddService(typeof(ApiExceptionFilterAttribute));
  12. })
  13. .SetCompatibilityVersion(CompatibilityVersion.Version_3_0)
  14. .AddNewtonsoftJson();
  15. }

做对应测试就可返回对应的类型

.Net Core--返回拦截统一处理返回值 - 图1

.Net Core--返回拦截统一处理返回值 - 图2

.Net Core--返回拦截统一处理返回值 - 图3

这种返回值就比较统一规范,提高了前后端的协作;