asp.net core webapi项目配置全局路由

一、前言


 在开发项目的过程中,我新创建了一个controller,发现vs会给我们直接在controller头添加前缀,比如[Route("api/[controller]")],即在访问接口的时候会变成http://localhost:8000/api/values,但是如果控制器有很多个,或者要进行版本迭代时,我们会发现痛苦的时刻降临了,要一个一个的修改。

如果在这个时候可以进行全局配置前缀那真是福利呀,修改一处即可。为了能达到此目的我们就来运用一下吧。

 

二、配置


 0、在配置前我们先来看看接口的前缀吧。立图为证 

640?wx_fmt=png

用swagger打开

640?wx_fmt=png

 

1、我们需要用到 IApplicationModelConvention  这个接口,它是位于 Microsoft.AspNetCore.Mvc.ApplicationModels 命令空间下面。

640?wx_fmt=png

 

MVC框架有一些约定俗成的东西,这个接口主就是用来定义一些MVC约定的东西。我们就可以通过 Apply方法中的 ApplicationModel  来修改或者添加一些约定,而且MV框架本身在启动的时候会把此接口注入,以便于我们使用。

不过我们还是要来看一下这个ApplicationModel  对象里面有什么我们可以用到的地方,我们继续深入:

640?wx_fmt=png

 

看到这是不是很爽,我们可以看一下 每个属性的给出的解释

ApiExplorerModel:包括描述信息,群组信息,可见性等。

ControllerModel:主要是 Comtroller 默认约定相关的了,这个里面东西就比较多了,有 控制器名称、路由值、Actions等,我们接下去的配置也将会在此展开

IFilterMetadata :空接口,主要起到标记的作用。

 

2、配置

第一步:先定义一个类,用来实现IApplicationModelConvention  接口。

/// <summary>

    /// 全局路由前缀配置

    /// </summary>

    public class RouteConvention : IApplicationModelConvention

    {

        /// <summary>

        /// 定义一个路由前缀变量

        /// </summary>

        private readonly AttributeRouteModel _centralPrefix;

        /// <summary>

        /// 调用时传入指定的路由前缀

        /// </summary>

        /// <param name="routeTemplateProvider"></param>

        public RouteConvention(IRouteTemplateProvider routeTemplateProvider)

        {

            _centralPrefix = new AttributeRouteModel(routeTemplateProvider);

        }


        //接口的Apply方法

        public void Apply(ApplicationModel application)

        {

            //遍历所有的 Controller

            foreach (var controller in application.Controllers)

            {

                // 1、已经标记了 RouteAttribute 的 Controller

          //这一块需要注意,如果在控制器中已经标注有路由了,则会在路由的前面再添加指定的路由内容。


                var matchedSelectors = controller.Selectors.Where(x => x.AttributeRouteModel != null).ToList();

                if (matchedSelectors.Any())

                {

                    foreach (var selectorModel in matchedSelectors)

                    {

                        // 在 当前路由上 再 添加一个 路由前缀

                        selectorModel.AttributeRouteModel = AttributeRouteModel.CombineAttributeRouteModel(_centralPrefix,

                            selectorModel.AttributeRouteModel);

                    }

                }


                //2、 没有标记 RouteAttribute 的 Controller

                var unmatchedSelectors = controller.Selectors.Where(x => x.AttributeRouteModel == null).ToList();

                if (unmatchedSelectors.Any())

                {

                    foreach (var selectorModel in unmatchedSelectors)

                    {

                        // 添加一个 路由前缀

                        selectorModel.AttributeRouteModel = _centralPrefix;

                    }

                }

            }

        }

    }

此处代码需要注意下,上面代码分为两部分,一部分是控制器有路由配置,一部分是没有路由配置。因此需要根据具体的情况来选择使用。

 

第二步:添加上面后,我们就定义一个类来插入我们的路由吧。

定义MvcOptionsExtensions.cs,此方法主要是扩展了MVCoptions类

640?wx_fmt=png

说明:routeAttribute 为我们自定的前缀内容。 

第三步:在startup.cs 里面ConfigureServices 方法添加配置信息

640?wx_fmt=png

说明:上面的方括号在这边是有效的。其中内容可以自定义。

 

第四步:运行

1、原先控制器路由前缀保留

640?wx_fmt=png

 

 

2、把原先的路由前缀去除

640?wx_fmt=png

 

三、总结


 至此,已很好的实现全局路由配置前缀啦。可以开心的玩耍啦。https://github.com/LouieGuo/GlobalRoutingPrefix

原文地址:https://www.cnblogs.com/guolianyu/p/9680899.html


 
 

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

640?wx_fmt=jpeg

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值