• webapi 集成swagger


    参考资料:Stack Overflow

    我自己写的demo:SwaggerDemoApi

    在已有的webapi项目或者创建webapi项目中,打开nuget管理器

    搜索:swagger

    安装截图中的插件到你的webapi项目中 ,安装完成后,项目根目录下也可能会出现SwaggerNet.cs文件,把这个文件删除掉即可

     

     这个插件是自动安装的,依赖于Swagger.Net.UI

    安装完成之后,发现项目根目录--App_Start目录下回产生两个文件

    打开SwaggerNet.cs文件,把我截图中的代码注释掉,不然会报错,报错信息:程序集“Swagger.Net, Version=0.5.1.0, Culture=neutral, PublicKeyToken=null”中的类型“Swagger.Net.XmlCommentDocumentationProvider”的方法“GetDocumentation”没有实现。

     把图中代码注释掉,就没有报错了。

    运行起来后,在地址栏后加上/swagger,就可以自动跳转到对应的页面了。

    集成到项目中报错:Not supported by Swagger 2.0: Multiple operations with path 'api/Blob' and method 'POST'. See the config setting - "ResolveConflictingActions" for a potential workaround

    参考资料:Not supported by Swagger 2.0: Multiple operations with path

                     webapi 配置swagger出现问题:not supported by swagger 2.0

    在代码

    GlobalConfiguration.Configuration 
                    .EnableSwagger(c =>
                        { ...

    里面加上一句:

    c.ResolveConflictingActions(apiDescriptions => apiDescriptions.ToList().First());

    或者

    c.ResolveConflictingActions(apiDescriptions => apiDescriptions.First());

    哪个不报错就用哪个,自己看情况。加上之后就不报这个错误了,就成功的运行出来了。

    2019.05.24 补充:

    如何生成注释文档?参考资料:代码注释生成

    2020.03.23 补充:

    如何添加header验证?

      GlobalConfiguration.Configuration
                    .EnableSwagger(c =>
                        {
                            c.OperationFilter<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 = "Authorization", @in = "header", description = "Token", required = true, type = "string" });
                }
            }
        }
  • 相关阅读:
    P4315 月下“毛景树”
    P1505 [国家集训队]旅游
    P3258 [JLOI2014]松鼠的新家
    P4116 Qtree3
    P2580 于是他错误的点名开始了
    P3038 [USACO11DEC]牧草种植Grass Planting
    P3128 [USACO15DEC]最大流Max Flow
    P2146 [NOI2015]软件包管理器
    P2590 [ZJOI2008]树的统计
    P3384 【模板】树链剖分
  • 原文地址:https://www.cnblogs.com/dawenyang/p/10911051.html
Copyright © 2020-2023  润新知