您好,登錄后才能下訂單哦!
這篇文章將為大家詳細講解有關Asp.Net Web API路由系統之如何部署WebHost,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
創建一個空的WebApi項目,在Global中注冊路由信息:
public class WebApiApplication : System.Web.HttpApplication { protected void Application_Start() { //注冊路由 GlobalConfiguration.Configuration.Routes.MapHttpRoute( name: "default", routeTemplate: "api/{controller}/{id}", defaults: new { id = RouteParameter.Optional }); } }
創建一個名為Home的Controller:
public class HomeController : ApiController { // GET: api/Home public IEnumerable<string> Get() { return new string[] { "value1", "value2" }; } // GET: api/Home/5 public string Get(int id) { return "value"; } }
啟動運行,在瀏覽器地址欄分別輸入http://localhost:46351/api/home和http://localhost:46351/api/home/5,結果如下:
簡單看了一下Asp.Net Web API的實例,下面我們開始剖析Asp.Net Web API的路由系統。
首先看一下在Asp.Net Web API中路由的注冊方式,如下:
在這個路由注冊過程中,隱藏了哪些操作呢?下面我們源碼:
通過翻看源碼可以看到,Asp.Net Web API中路由的注冊實際上是通過調用HttpRouteCollection類型的擴展方法MapHttpRoute實現的,在MapHttpRoute方法里面,我們看到創建的路由對象通過調用HttpRouteCollection對象的Add方法保存了。而由于GlobalConfiguration的靜態屬性通過Configuration是HostedHttpRouteCollection類型以RouteTable.Routes為構造參數創建的,又因為HostedHttpRouteCollection類型是HttpRouteCollection類型的子類,在HostedHttpRouteCollection類型中,子類HostedHttpRouteCollection重寫了父類型的Add方法和CreateRoute方法,如下圖,所以,實際上創建出來的路由對象的類型為HostedHttpRoute,此路由對象放到全局路由表中保存了,從這里我們可以知道,保存到全局路由表中的路由對象的類型為HostedHttpRoute。那么,注冊的路由對象放到全局路由表中保存有什么用呢,后續部分分析。
從上面源碼可以看到,最后創建的路由對象是HostedHttpRoute類型,那么現在有個問題,我們在前面注冊路由的時候,并沒有指定RouteHandler和HttpHandler,它們是從哪里添加到路由對象中的呢?在創建HostedHttpRoute對象的過程中,又有哪些隱藏的秘密呢?我們下面繼續查看源碼:
通過上文的剖析,到目前為止,我們可以知道在Asp.Net Web API以WebHost方式寄宿時,注冊的路由對象為HostedHttpRoute類型的實例,保存在全局路由表RouteTable.Routes中,而用于處理請求的RouteHandler和HttpHandler分別為HttpControllerRouteHandler類型的實例和HttpControllerHandler類型的實例。
注冊完路由信息后,在Asp.Net Web API中是如何利用注冊的路由信息進行路由的呢?會不會也是跟Asp.Net中一樣通過一個HttpModule來實現的呢,我們啟動程序看一下Global類中的Modules屬性:
從上面截圖可以清楚看到,在Asp.Net Web API以WebHost方式寄宿服務時,也是跟ASP.Net一樣,通過UrlRoutingModule來實現路由的。從上一篇針對Asp.Net路由系統的剖析中,我們可以知道,Asp.Net是通過UrlRoutingModule對請求進行攔截后,然后從全局路由表中依次進行匹配以獲取與請求Url匹配的RouteData進行后續處理的。在Asp.Net Web API中,從上文中我們知道了保存在全局路由表的路由對象是HostedHttpRoute類型的,下面我們繼續剖析在Asp.Net Web API中最終是怎么獲取到匹配的RouteData的。
在UrlRoutingModule中,RouteData是通過依次調用每個路由對象的GetRouteData方法獲取的。在Asp.Net Web API中,由于路由對象的類型為HostedHttpRoute,下面我們來看看調用GetRouteData方法時發生了什么:
可以看到,在HostedHttpRoute中是通過屬性OriginalRoute的GetRouteData方法獲取RouteData的,由前文的剖析中,我們知道這個OriginalRoute屬性是HttpWebRoute類型:
從上面剖析中可以看到,Asp.Net Web API以WebHost方式部署時,最終還是通過Asp.Net的路由系統完成匹配工作。不過有一定需要注意的是,由于在HttpWebRoute中對父類型的驗證約束的方法進行了重寫,所以對于約束的驗證,Asp.Net Web API還是使用了自己的方式進行驗證約束是否匹配:
最后,通過一系列的工作獲取到了RouteData對象和包含在里面的RouteHandler、HttpHandler后,Asp.Net Web API就可以通過這些獲取到的進行請求的處理和響應了。
通過上文的剖析,可以得出:在Asp.Net Web API以WebHost方式部署時,注冊的路由是保存在全局路由表中的;在獲取RouteData時,是通過Asp.Net路由系統的匹配規則進行路由匹配的,不過卻實現了自己的約束驗證規則。
關于“Asp.Net Web API路由系統之如何部署WebHost”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。