• 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、管道、中间件等,我也是在学习中希望和大家一起相互印证。

                

  • 相关阅读:
    Protobuf
    iOS保持App真后台运行
    oc之考试答题类效果
    oc之脚本
    IOS
    Xcode中控制台中打印中文处理
    iOS-拍照后裁剪,不可拖动照片的问题
    iOS开发之一句代码检测APP版本的更新
    AVAudioSesion和AVAudioPlayer的基本使用
    GCD使用dispatch_semaphore_t创建多线程网络同步请求
  • 原文地址:https://www.cnblogs.com/szlblog/p/8111577.html
Copyright © 2020-2023  润新知