.NETCORE中关于swagger的分组

有些时候我们的项目接口过多,就希望对应的swagger能够执行分组,网络上的几乎是千篇一律的分组方法,会累死!

这里提供一个更加高效的分组方法,比如你可以说哪些模块分到哪个组,哪些权限分到哪个组!

先上代码:

                    //添加文档
                    options.SwaggerDoc("v1", new OpenApiInfo { Title = "基础的接口", Version = "v1" });
                    options.SwaggerDoc("open", new OpenApiInfo { Title = "公开的接口", Version = "open" });
                    options.SwaggerDoc("role", new OpenApiInfo { Title = "需要登陆的接口", Version = "role" });
                    options.DocInclusionPredicate((doc, api) =>
                    {
                        if (!api.TryGetMethodInfo(out System.Reflection.MethodInfo method))
                        {
                            Console.WriteLine("not method!");
                            return false;
                        }
                        //路径过滤,有时候我们基于其他模块的,可以基于路径屏蔽
                        //return (description.RelativePath.Contains("/app/") || description.RelativePath.Contains("/plan/"));
                        //查找Method的 也就是Action的
                        var _api0 = method.GetCustomAttributes(true).OfType<TypeFilterAttribute>().ToList();
                        foreach (var item in _api0)
                        {
                            if (item.ImplementationType == typeof(RoleAttribute))
                            {
                                return doc == "role";
                            }
                            //item.Arguments //这个就是过滤器的参数了
                        }
                        //查找外部的 也就是Controller的
                        if (method.ReflectedType != null)
                        {
                            var _apix = method.ReflectedType.GetCustomAttributes(true).OfType<TypeFilterAttribute>().ToList();
                            foreach (var item in _apix)
                            {
                                if (item.ImplementationType == typeof(RoleAttribute))
                                {
                                    return doc == "role";
                                }
                            }
                        }
                        //查找不是通过TypeFilter安装过滤器的
                        var _api1 = method.GetCustomAttributes(true).OfType<RoleAttribute>().Count();
                        if (_api1 > 0)
                        {
                            return doc == "role";
                        }
                        if(doc == "role") { return false; }
                        if(doc == "open") { return true; }
                        //v1全部显示
                        return doc == "v1";
                    });

上面中,RoleAttribute是我自定义的过滤器,用于校验权限的,就是当前登陆者拥有哪些权限,我们一般用2个地方添加过滤器,一个是添加到Controller上,他的所有Action都会生效这个过滤器,一个是直接在Action上添加过滤器,其实还有一个是全局注入,不过我觉得那个很少用。

带参形式的过滤器

        [HttpPost]
        [TypeFilter(typeof(RoleAttribute), Arguments = new object[] { "root", "root" })]
        public async Task<string> AddChat(ChatItemAddDto input)
        {
            return "发布成功";
        }

不带参数的过滤器

        [HttpPost]
        [RoleAttribute]
        public async Task<string> ReadMessage(int roomid = 0, int uid = 0)
        {
            return "";
        }

直接加入Controller里面的,他下面的所有Action都生效

    [ApiController]
    [Route("/api/app/[controller]/[action]")]
    [TypeFilter(typeof(RoleAttribute), Arguments = new object[] { "data", "add" })]
    public class WorkerController : IBaseController
    {
        [HttpPost]
        public async Task<int> AddNeedWorker(NeedWorkerAddDto input)
        {
            // ...
            return 1;
        }
    }

上面的文档判断其实还是有待改进的地方,不过留给大家自己折腾,毕竟需求不一样!

你可以按照过滤器的参数划分分组,也可以按照不同过滤器划分分组!

最后启用UI,代码如下

            app.UseAbpSwaggerUI(options =>
            {
                options.SwaggerEndpoint("/swagger/v1/swagger.json", "Support APP API");
                options.SwaggerEndpoint("/swagger/open/swagger.json", "公开的接口");
                options.SwaggerEndpoint("/swagger/role/swagger.json", "需要登陆的接口");
                //options.DocExpansion(DocExpansion.None);//是否展开或者收缩
            });

看别人的都是通过

        [ApiExplorerSettings(GroupName ="v1")]

来划分的,虽然灵活,但是累啊!都已经用权限拆分了,还折腾这个分组干嘛呢!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

贴代码科技-致力于开发更加适用的应用

要不请我喝杯咖啡!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值