zoukankan      html  css  js  c++  java
  • AspNet Core Api Restful +Swagger 实现微服务之旅(四)

    这几天没更新,项目框架也是在发展阶段,这几天学习配置了一遍Apollo和RabbitMQ 等到放到框架上之后我整理一下到时候把心得写出来相互学习。

    接着上一篇的内容

          (2)  程序错误时  返回数据格式封装

          (3)  返回结果包装

          (4)  对外开放的接口 参数必填与非必填的声明

       (2)  程序错误时  返回数据格式封装/(3)返回结果包装

             2.1创建捕获异常类当有异常发生时自定义返回信息 WebApiException

     public class WebApiException : IExceptionFilter
        {
            /// <summary>
            /// 监控程序错误
            /// </summary>
            /// <param name="context"></param>
            public void OnException(ExceptionContext context)
            {
                NewMethod(context);
            }
            private static void NewMethod(ExceptionContext context)
            {
                if (context.Exception is Exception)
                {
                    var objectResult = context.Exception as Exception;
                    if (objectResult.Message != null)
                    {
                        context.Result = new ObjectResult(new { Success = false,  msg = "你的程序有误!" });
                        //写入日志
                    }
                }
            }
    
        }
    View Code

                 2.2创建 结果封装类  WebApiResultMiddleware  返回结果封装成统一的样式

       public class WebApiResultMiddleware : ActionFilterAttribute
        {
            /// <summary>
            ///  对返回的结果进行统一的 格式
            /// </summary>
            /// <param name="context"></param>
            public override void OnResultExecuting(ResultExecutingContext context)
            {
                //根据实际需求进行具体实现
                if (context.Result is ObjectResult)
                {
                    var objectResult = context.Result as ObjectResult;
                    if (objectResult.Value == null)
                    {
                        context.Result = new ObjectResult(new {   Success=false, code = 404, msg = "未找到资源", data ="null" }); 
                    }
                    else
                    {
                        context.Result = new ObjectResult(new { Success = true ,code = 200, msg = "成功!", Data = objectResult.Value }); 
                    }
                }
              
            }
        }
    View Code

                2.3 在startup.cs 启动容器中注册 服务

     services.AddMvc(options =>
                {
                    //方法返回结果统一化
                    options.Filters.Add(typeof(WebApiResultMiddleware));
                    //程序错误返回结果统一化
                    options.Filters.Add(typeof(WebApiException));
                    //身份验证不通过是返回结果统一化
                    options.Filters.Add(typeof(WebApiAuthorizationFilter));
                    options.RespectBrowserAcceptHeader = true;
                });
    View Code

               返回结果就不在演示了,通过这三个类 我们能做很多的事情,比如写一个录入日志的方法就可以解决整个框架的写日志问题。

    (4)  对外开放的接口 参数必填与非必填的声明

     

    生成的路径样式

    对控制器的包装  支持传输参数的的声明

    我想先把基础的东西写下来 为以后做准备。

    比如,路由的配置、DI、管道、中间件等,我也是在学习中希望和大家一起相互印证。

                

  • 相关阅读:
    pip 安装用 国内清华大学的数据源
    sql server 中导出图片并命名
    金跌 K3 科目表
    SQLSERVER 循环
    语句判断记录是否存在(最简洁简单性能最优)
    增、删、改开放时间表时,同步数据至 CP
    [网络流24题] 圆桌问题(最大流)
    [网络流24题] 最小路径覆盖问题(匈牙利 最大流)
    C. Vasya And Array (贪心构造)
    【牛客网】一个有意思的前缀和题目
  • 原文地址:https://www.cnblogs.com/szlblog/p/8111577.html
Copyright © 2011-2022 走看看