Asp.Net Core WebAPI使用Swagger时API隐藏与分组

1、前言

为什么我们要隐藏部分接口?

因为我们在用swagger代替接口的时候,难免有些接口会直观的暴露出来,比如我们结合Consul一起使用的时候,会将健康检查接口以及报警通知接口暴露出来,这些接口有时候会出于方便考虑,没有进行加密,这个时候我们就需要把接口隐藏起来,只有内部的开发者知道。

为什么要分组?

通常当我们写前后端分离的项目的时候,难免会遇到编写很多接口供前端页面进行调用,当接口达到几百个的时候就需要区分哪些是框架接口,哪些是业务接口,这时候给swaggerUI的接口分组是个不错的选择。

640?wx_fmt=png

swagger的基本使用这里将不再赘述,可以阅读微软官方文档,即可基本使用

2、swaggerUI中加入授权请求

  • 新建 HttpHeaderOperationFilter 操作过滤器,继承 Swashbuckle.AspNetCore.SwaggerGen.IOperationFilter 接口,实现 Apply 方法

    /// <summary>
    /// swagger请求头
    ///
    </summary>
    public class HttpHeaderOperationFilter : IOperationFilter
    {
    public
    void Apply(Operation operation, OperationFilterContext context)
    {
    #region
    新方法
    if (operation.Parameters == null)
    {
    operation.Parameters
    = new List<IParameter>();
    }

    if
    (context.ApiDescription.TryGetMethodInfo(out MethodInfo methodInfo))
    {
    if
    (!methodInfo.CustomAttributes.Any(t => t.AttributeType == typeof(AllowAnonymousAttribute))
    &&!(methodInfo.ReflectedType.CustomAttributes.Any(t => t.AttributeType == typeof(AuthorizeAttribute))))
    {
    operation.Parameters.Add(new NonBodyParameter
    {
    Name
    = "Authorization",
    In
    = "header",
    Type
    = "string",
    Required
    = true,
    Description
    = "请输入Token,格式为bearer XXX"
    });
    }
    }
    #endregion


    #region 已过时
    //if (operation.Parameters == null)
    //{
    // operation.Parameters = new List<IParameter>();
    //}
    //var actionAttrs = context.ApiDescription.ActionAttributes().ToList();
    //var isAuthorized = actionAttrs.Any(a => a.GetType() == typeof(AuthorizeAttribute));
    //if (isAuthorized == false)
    //{
    // var controllerAttrs = context.ApiDescription.ControllerAttributes();
    // isAuthorized = controllerAttrs.Any(a => a.GetType() == typeof(AuthorizeAttribute));
    //}
    //var isAllowAnonymous = actionAttrs.Any(a => a.GetType() == typeof(AllowAnonymousAttribute));
    //if (isAuthorized && isAllowAnonymous == false)
    //{
    // operation.Parameters.Add(new NonBodyParameter
    // {
    // Name = "Authorization",
    // In = "header",
    // Type = "string",
    // Required = true,
    // Description = "请输入Token,格式为bearer XXX"
    // });
    //}

    #endregion
    }

    }

  • 然后修改 Startup.cs 中的 ConfigureServices 方法,添加我们自定义的 HttpHeaderOperationFilter 过滤器

    public IServiceProvider ConfigureServices(IServiceCollection services)
    {
    ...
    services.AddSwaggerGen(c
    =>
    {
    ...

    c.OperationFilter
    <HttpHeaderOperationFilter>();
    });
    .
    ..
    }

    这时候我们再访问swaggerUI就可以输入Token了
    640?wx_fmt=png

3、API分组

  • 修改 Startup.cs 中的 ConfigureServices 方法,添加多个swagger文档

    public IServiceProvider ConfigureServices(IServiceCollection services)
    {
    ...
    services.AddSwaggerGen(c
    =>
    {
    c.SwaggerDoc("
    v1", new Info
    {
    Version
    = "v1",
    Title
    = "接口文档",
    Description
    = "接口文档-基础",
    TermsOfService
    = "",
    Contact
    = new Contact
    {
    Name
    = "XXX1111",
    Email
    = "XXX1111@qq.com",
    Url
    = ""
    }
    });

    c.SwaggerDoc("
    v2", new Info
    {
    Version
    = "v2",
    Title
    = "接口文档",
    Description
    = "接口文档-基础",
    TermsOfService
    = "",
    Contact
    = new Contact
    {
    Name
    = "XXX2222",
    Email
    = "XXX2222@qq.com",
    Url
    = ""
    }
    });

    //反射注入全部程序集说明

    GetAllAssemblies().Where(t => t.CodeBase.EndsWith("Controller.dll")).ToList().ForEach(assembly =>
    {
    c.IncludeXmlComments(assembly.CodeBase.Replace(".dll"
    , ".xml"));
    });

    c.OperationFilter
    <HttpHeaderOperationFilter>();
    //c.DocumentFilter<HiddenApiFilter>();

    });
    ...
    }
  • 修改 Startup.cs 中的 Configure 方法,加入

    public void Configure(IApplicationBuilder app, ILoggerFactory loggerFactory)
    {
    ...
    app.UseSwagger();
    app.UseSwaggerUI(c
    =>
    {
    c.SwaggerEndpoint("/swagger/v2/swagger.json"
    , "接口文档-基础");//业务接口文档首先显示
    c.SwaggerEndpoint("/swagger/v1/swagger.json", "接口文档-业务");//基础接口文档放后面后显示
    c.RoutePrefix = string.Empty;//设置后直接输入IP就可以进入接口文档
    });
    ...

    }
  • 然后还要在我们的控制器上面标注swagger文档的版本
    640?wx_fmt=png

    这时候我们就可以将接口文档进行分组显示了
    640?wx_fmt=png

4、API隐藏

  • 创建自定义隐藏特性 HiddenApiAttribute.cs 

    /// <summary>
    /// 隐藏swagger接口特性标识
    ///
    </summary>
    [AttributeUsage(AttributeTargets.Method | AttributeTargets.Class)]
    public
    class HiddenApiAttribute:System.Attribute
    {
    }
  • 创建API隐藏过滤器 HiddenApiFilter 继承 Swashbuckle.AspNetCore.SwaggerGen.IDocumentFilter 接口,实现 Apply 方法

    /// <summary>
    /// 自定义Swagger隐藏过滤器
    ///
    </summary>
    public class HiddenApiFilter : IDocumentFilter
    {
    public
    void Apply(SwaggerDocument swaggerDoc, DocumentFilterContext context)
    {
    foreach
    (ApiDescription apiDescription in context.ApiDescriptions)
    {
    if
    (apiDescription.TryGetMethodInfo(out MethodInfo method))
    {
    if
    (method.ReflectedType.CustomAttributes.Any(t=>t.AttributeType==typeof(HiddenApiAttribute))
    || method.CustomAttributes.Any(t => t.AttributeType == typeof(HiddenApiAttribute)))
    {
    string
    key = "/" + apiDescription.RelativePath;
    if
    (key.Contains("?"))
    {
    int
    idx = key.IndexOf("?", System.StringComparison.Ordinal);
    key
    = key.Substring(0, idx);
    }
    swaggerDoc.Paths.Remove(key);
    }
    }
    }
    }
    }
  • 在 Startup.cs 中使用 HiddenApiFilter 

    public IServiceProvider ConfigureServices(IServiceCollection services)
    {
    ...
    services.AddSwaggerGen(c
    =>
    {
    c.SwaggerDoc("v1"
    , new Info
    {
    Version
    = "v1",
    Title
    = "接口文档",
    Description
    = "接口文档-基础",
    TermsOfService
    = "",
    Contact
    = new Contact
    {
    Name
    = "XXX1111",
    Email
    = "XXX1111@qq.com",
    Url
    = ""
    }
    });

    c.SwaggerDoc("v2"
    , new Info
    {
    Version
    = "v2",
    Title
    = "接口文档",
    Description
    = "接口文档-基础",
    TermsOfService
    = "",
    Contact
    = new Contact
    {
    Name
    = "XXX2222",
    Email
    = "XXX2222@qq.com",
    Url
    = ""
    }
    });

    //反射注入全部程序集说明

    GetAllAssemblies().Where(t => t.CodeBase.EndsWith("Controller.dll")
    && !t.CodeBase.Contains("Common.Controller.dll")).ToList().ForEach(assembly =>
    {
    c.IncludeXmlComments(assembly.CodeBase.Replace(".dll"
    , ".xml"));
    });

    c.OperationFilter
    <HttpHeaderOperationFilter>();
    c.DocumentFilter
    <HiddenApiFilter>();
    });
    ...
    }
  • 示例:
    我这里提供了Consul的心跳检车接口
    640?wx_fmt=png

    但是在接口文档中并没有显示出来
    640?wx_fmt=png

原文地址:https://www.cnblogs.com/wyt007/p/10650974.html

.NET社区新闻,深度好文,欢迎访问公众号文章汇总 http://www.csharpkit.com
640?wx_fmt=jpeg


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/316441.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

cf1526E. Oolimry and Suffix Array(未解决)

E. Oolimry and Suffix Array 题意&#xff1a; 给定n&#xff0c;k和长度为n的后缀数组si(0<si<n-1),求长度为n的由k种字母构成的字符串种&#xff0c;后缀数组为si的有多少种 题解&#xff1a; 题解看懂了一半。。。等会了再更新 代码&#xff1a;

P2572 [SCOI2010]序列操作

P2572 [SCOI2010]序列操作 题意&#xff1a; 一个长度为n的01序列&#xff0c;下标从0开始&#xff0c;现在有五种变换操作和询问操作&#xff1a; 0 l r 把[l,r]区间内的所有数全变成01 l r 把[l,r]区间内的所有数全变成12 l r把[l,]区间内所有数全部取反3 l r询问[l,r]区间…

为您的机器配置开发环境

软件准备在本期视频中&#xff0c;我们将安装所序言的软件&#xff0c;并为我们的电脑配置.NET Core开发环境。我们需要安装如下2个软件&#xff1a;一个编辑器.NET Core SDK&#xff08;Software Development Kit&#xff09;下载并安装.NET Core 开发编辑器我的是Windows操作…

[CQOI2012] 局部极小值(状压DP + 容斥 + 搜索)

problem luogu-P3160 solution 这么小的数据范围&#xff0c;非暴力不状压。暴力 O(28!)O(28!)O(28!) 呵呵呵可以拉走了。 我们不妨从小到大填数字&#xff0c;这样如果局部极小值点还没有填的话&#xff0c;周围的九宫格就一定不能被填。 设 dp(s,i):dp(s,i):dp(s,i): 局…

基于Kubernetes 构建.NET Core 的技术体系

很多公司技术支持岗位的工作&#xff0c;如配置域名&#xff0c;部署环境&#xff0c;修改复位配置&#xff0c;服务重启&#xff0c;扩容缩容&#xff0c;梳理和完善监控&#xff0c;根据开发的需要查找日志等工作&#xff0c;需要和开发进行大量的沟通&#xff0c;如什么是外…

P4062 [Code+#1]Yazid 的新生舞会(分治做法)

P4062 [Code#1]Yazid 的新生舞会 题意&#xff1a; 给出一个序列&#xff0c;求有多少个子区间满足众数的出现次数大于区间长度的一半。 出现次数大于区间长度的一般我们称之为绝对众数 题解&#xff1a; 分治做法 对于一个区间[l,r]&#xff0c;设mid⌊lr2⌋\lfloor \frac…

[CQOI2014] 危桥(网络流)

problem luogu-P3163 solution 这是一道网络流好题&#xff0c;看的着摸不着吃不着。 初读完题&#xff0c;就知道这是一道“脱光了”的最大流。 建图基础版本&#xff1a; 建立额外源汇点。 无向边相同于两条有向边&#xff0c;直接建不影响&#xff0c;危桥流量设成 22…

那些优秀的开发者----汪宇杰:从重视细节,到成就技术专家

汪宇杰&#xff08;Edi Wang&#xff09;&#xff0c;.NET及Windows开发者&#xff0c;2018-2019年度微软最有价值专家&#xff08;Windows Development方向&#xff09;。现担任某金融科技企业的网站开发工程师。他对微软技术有鉴定的信念和不灭的热情&#xff0c;曾在Windows…

P4062 [Code+#1]Yazid 的新生舞会(线段树做法)

P4062 [Code#1]Yazid 的新生舞会&#xff08;线段树做法&#xff09; 题意&#xff1a; 给你一个序列a[1…n]​&#xff0c;求存在绝对众数的子区间个数。 绝对众数指&#xff1a;区间中出现次数最多的那个数&#xff0c;出现次数严格大于区间长度的一半。 题解&#xff1a…

《从零开始学ASP.NET CORE MVC》课程介绍

大家好&#xff0c;欢迎来到52ABP学院&#xff0c;收看我们的 《从零开始学ASP.NET CORE MVC》。ASP.NET Core 简介从2015年开始随时互联网成长&#xff0c;云计算和AI、大数据的爆发&#xff0c;大家从谈论项目信息化到数字化的转型&#xff0c;从ToC产业到ToB产业的转型&…

[ZJOI2015] 地震后的幻想乡(状压dp + 期望)

problem luogu-P3343 solution dp(i):dp(i):dp(i): 当恰好加入第 iii 小边时候&#xff0c;所有点联通的方案数。 则 ans∑idpi(mi)im1ans\sum_i \frac{dp_i}{\binom mi}\frac{i}{m1}ans∑i​(im​)dpi​​m1i​ 。 重点是如何计算出 dp(i)dp(i)dp(i)。 这个恰好的限制不好…

P2152 [SDOI2009]SuperGCD

P2152 [SDOI2009]SuperGCD 题意&#xff1a; 求a和b的最大公约数 a,b<101000010^{10000}1010000 题解&#xff1a; 高精度&#xff0c;java高精度直接有模板&#xff0c;c高精度结合gcd的辗转相减法 对于&#xff1a;a,b的gcd(a,b)有&#xff1a; 若a为奇数&#xff0c…

Docker - 容器部署 Consul 集群

目录 准备 Consul 镜像安装单个 Consul组装集群 Consul启动 Consul 和 Web 管理器Consul 命令简单介绍Web 管理器Server 加入集群Client 加入集群了解 ConsulConsul 使用场景Consul 优势Consul 中的概念说明简介安装总结引用和附件说明本文主要介绍怎么使用 Docker 在 Linux…

[LOJ3153] 三级跳(单调栈 + 线段树)

problem loj3153 solution 有一个显然正确但又不起眼却是正解必备的结论&#xff1a; 考虑 (x,y,z)(x,y,z)(x,y,z) 答案三元对&#xff0c;如果有一个数 i∈(x,y)∧ai≥axi\in(x,y)\wedge a_i\ge a_xi∈(x,y)∧ai​≥ax​&#xff0c;那么 (i,y,z)(i,y,z)(i,y,z) 一定是不劣…

P2167 [SDOI2009]Bill的挑战

P2167 [SDOI2009]Bill的挑战 题意&#xff1a; 有n个长度一样的字符串&#xff0c;字符串的每一位是&#xff1f;或者确定的字母&#xff0c;&#xff0c;求与这 N 个串中的刚好 K 个串匹配的字符串 T 的个数 1<N<15,1<|S|<50 题解&#xff1a; 很明显状态dp 我…

VS2017创建ASP.NET Core Web程序

创建ASP.NET Core Web应用程序如果您使用的是VS2019 请看 VS2019创建ASP.NET Core Web程序在这个视频中我们将讨论可用的不同项目模板及其功能预制的项目模板有什么不同&#xff0c;哪些是可以使用的&#xff0c;以及他们的作用。在Visual Studio2017中创建新的ASP.NET Core 项…

[ZJOI2015] 幻想乡战略游戏(树链剖分 + 线段树二分 + 带权重心)

problem luogu-P3345 solution 这是一个带权重心的题&#xff0c;考察动态点分治。点分治&#xff1f;呵&#xff0c;不可能的&#xff0c;这辈子都不可能写点分治 我们重新考虑重心的性质&#xff1a;以这个点为根时&#xff0c;所有子树的大小不会超过整体大小的一半。 …

巧用linux版powershell,管理linux下的docker

owershell,docker,cli,命令,docker ps,docker image第一章 在linux中搭建docker环境目的&#xff1a;在任意版本的linux&#xff08;物理机&#xff0c;虚拟机&#xff0c;节点机&#xff09;中&#xff0c;安装docker服务。动作&#xff1a;教程略&#xff0c;不是本文主要目的…

P1972 [SDOI2009]HH的项链

P1972 [SDOI2009]HH的项链 题意&#xff1a; 给你一个序列&#xff0c;问这个序列中的种类数 n,m,ai<1e6 题解&#xff1a; 三个方法&#xff1a;莫队(会超时)&#xff0c;树状数组&#xff0c;主席树(会超时) 莫队就是裸题&#xff0c;不讲了&#xff0c;复杂度O(n*sq…

从ASP.NET Core2.2到3.0你可能会遇到这些问题

趁着假期的时间所以想重新学习下微软的官方文档来巩固下基础知识。我们都知道微软目前已经发布了.NET Core3.0的第三个预览版&#xff0c;同时我家里的电脑也安装了vs2019。So&#xff0c;就用vs2019.NET Core3.0来跟着做一下Contoso University这个WEB应用&#xff0c;但是在基…