zoukankan      html  css  js  c++  java
  • Swagger相关配置记录

    1、SwaggerConfig文件配置

     public class SwaggerConfig
        {
            protected static string GetXmlCommentsPath()
            {
                return System.String.Format(@"{0}inxxx.OMS.WebApi.Partner.XML", System.AppDomain.CurrentDomain.BaseDirectory);
            }
    
            protected static string GetCommonXmlCommentsPath()
            {
                return System.String.Format(@"{0}inxxx.OMS.Common.XML", System.AppDomain.CurrentDomain.BaseDirectory);
            }
    
            protected static string GetDtoXmlCommentsPath()
            {
                return System.String.Format(@"{0}inxxx.OMS.Data.XML", System.AppDomain.CurrentDomain.BaseDirectory);
            }
    
            protected static string GetXFCCommentsPath()
            {
                return System.String.Format(@"{0}inxxx.XML", System.AppDomain.CurrentDomain.BaseDirectory);
            }
    
            private static bool ResolveVersionSupportByRouteConstraint(ApiDescription apiDesc, string targetApiVersion)
            {
                //过滤由多版本的controller带来的重复route注册api desc,按命名空间的版本信息过滤,只返回版本内的api
                return apiDesc.ActionDescriptor.ControllerDescriptor.ControllerType.FullName.ToLower().Contains(string.Format(".{0}.", targetApiVersion));
            }
    
            public static void Register()
            {
                var thisAssembly = typeof(SwaggerConfig).Assembly;
    
                GlobalConfiguration.Configuration
                    .EnableSwagger(c =>
                    {
                        c.SingleApiVersion("v1", "xxx.OMS.WebApi.Partner");
                        c.SchemaId(x => x.FullName);  //避免类型命名冲突
                        c.IncludeXmlComments(GetCommonXmlCommentsPath());
                        c.IncludeXmlComments(GetXmlCommentsPath());
                        c.IncludeXmlComments(GetDtoXmlCommentsPath());
                        c.IncludeXmlComments(GetXFCCommentsPath());
                        c.OperationFilter<HttpHeaderFilter>();
                        c.ResolveConflictingActions(apiDescriptions => apiDescriptions.First());
                    })
                    .EnableSwaggerUi(c =>
                    {
                        c.DisableValidator();
                    });
            }
        }

    2、HttpHeaderFilter 请求头参数设置

    public class HttpHeaderFilter : IOperationFilter
        {
            public void Apply(Operation operation, SchemaRegistry schemaRegistry, ApiDescription apiDescription)
            {
                if (operation.parameters == null) operation.parameters = new List<Parameter>();
                var filterPipeline = apiDescription.ActionDescriptor.GetFilterPipeline();
                //判断是否添加权限过滤器
                var isAuthorized = filterPipeline.Select(filterInfo => filterInfo.Instance).Any(filter => filter is IAuthorizationFilter);
                //判断是否允许匿名方法
                var allowAnonymous = apiDescription.ActionDescriptor.GetCustomAttributes<AllowAnonymousAttribute>().Any();
                if (isAuthorized && !allowAnonymous)
                {
                    operation.parameters.Add(new Parameter
                    {
                        name = "appId",
                        @in = "header",
                        description = "应用Id",
                        required = true,
                        type = "string"
                    });
    
                    operation.parameters.Add(new Parameter
                    {
                        name = "accessToken",
                        @in = "header",
                        description = "接口访问token",
                        required = true,
                        type = "string"
                    });
                }
            }
        }

    3、AccessTokenAttribute身份认证

     public class AccessTokenAttribute : AuthorizeAttribute
        {
            /// <summary>
            /// 获取认证服务
            /// </summary>
            /// <returns></returns>
            private IOpenAuthService GetAuthService()
            {
                return xxx.OMS.Service.Common.ServiceMediatorManager.OpenAuthService;
            }
    
            /// <summary>
            /// 权限验证
            /// </summary>
            /// <param name="actionContext"></param>
            /// <returns></returns>
            protected override bool IsAuthorized(HttpActionContext actionContext)
            {
                var request = actionContext.Request;
                if (request.Headers.Contains("appId") 
                    && request.Headers.Contains("accessToken"))
                {
                    var appId = request.Headers.GetValues("appId").SingleOrDefault();
                    var accessToken = request.Headers.GetValues("accessToken").SingleOrDefault();
    
                    var authRequest = new AuthRequest()
                    {
                        AppId = appId,
                        AccessToken = accessToken
                    };
    
                    var checkResult = GetAuthService().Check(authRequest);
                    if (!checkResult.isOk || !checkResult.retBody)
                    {
                        return false;
                    }
    
                    var accountResult = GetAuthService().GetAccount(authRequest);
                    if (!accountResult.isOk || accountResult.retBody == null)
                    {
                        return false;
                    }
    
                    var account = accountResult.retBody;
                    var customer = new CustomerInfo
                    {
                        AppId = account.AppId,
                        SupplierId = account.SupplierId,
                        SupplierName = account.SupplierName
                    };
    
                    HttpContext.Current.User = new CustomerPrincipal(new CustomerIdentity(customer));
                    return true;
                }
                return false;
            }
    
            /// <summary>
            /// 处理未授权的请求
            /// </summary>
            /// <param name="actionContext"></param>
            protected override void HandleUnauthorizedRequest(HttpActionContext actionContext)
            {
                var content = JsonConvert.SerializeObject(new ResultObject() { retStatus = 401, retMsg = "appId或者accessToken无效" });
                actionContext.Response = new HttpResponseMessage
                {
                    Content = new StringContent(content, Encoding.UTF8, "application/json"),
                    StatusCode = HttpStatusCode.OK
                };
            }
        }

    4、JsonDateTimeConverter Json日期转换

    /// <summary>  
        /// Json日期带T格式转换  
        /// </summary>  
        public class JsonDateTimeConverter : IsoDateTimeConverter
        {
            public override object ReadJson(JsonReader reader, Type objectType, object existingValue, JsonSerializer serializer)
            {
                DateTime dataTime;
                if (DateTime.TryParse(reader.Value.ToString(), out dataTime))
                {
                    return dataTime;
                }
                else
                {
                    return existingValue;
                }
            }
    
            /// <summary>
            /// 格式化
            /// </summary>
            public JsonDateTimeConverter()
            {
                DateTimeFormat = "yyyy-MM-dd HH:mm:ss";
            }
        }  
  • 相关阅读:
    数据库同步软件介绍以及使用说明(SyncNavigator多元异构数据实时同步工具)
    关于异构数据库的不同表之间数据同步的操作细节---syncnavigator同步工具实操
    ASP.NET Core 配置文件(无处不在的依赖注入)
    ASP.NET Core 开源项目整理
    性能差异 ASP.NET WebForm与ASP.NET MVC
    MySQL 分区知识点(三)
    Docker 资料
    MySQL 基础知识(基本架构、存储引擎差异)
    MySQL InnoDB与MyISAM存储引擎差异
    MySQL 索引知识整理(创建高性能的索引)
  • 原文地址:https://www.cnblogs.com/huangzelin/p/10711904.html
Copyright © 2011-2022 走看看