溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Controller激活與URL路由的示例分析

發(fā)布時間:2021-11-30 15:21:39 來源:億速云 閱讀:140 作者:小新 欄目:編程語言

這篇文章主要為大家展示了“Controller激活與URL路由的示例分析”,內(nèi)容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學(xué)習(xí)一下“Controller激活與URL路由的示例分析”這篇文章吧。

Controller的激活與URL路由

ASP.NET路由系統(tǒng)是HTTP請求抵達(dá)服務(wù)端的第一道屏障,它根據(jù)注冊的路由規(guī)則對攔截的請求進(jìn)行匹配并解析包含目標(biāo)Controller和Action名稱的路由信息。而當(dāng)前ControllerBuilder具有用于激活Controller對象的ControllerFactory,現(xiàn)在看看兩者是如何結(jié)合起來的。

通過第2章“URL路由”的介紹我們知道,ASP.NET路由系統(tǒng)的核心是一個叫做UrlRoutingModule的HttpModule,路由的實現(xiàn)是它通過注冊代表HttpApplication的PostResolveRequestCache事件對HttpHandler的動態(tài)映射來實現(xiàn)的。具體來說,它通過以RouteTable的靜態(tài)屬性Routes代表的全局路由表對請求進(jìn)行匹配并得到一個RouteData對象。RouteData具有一個實現(xiàn)了接口IRouteHandler的屬性RouteHandler,通過該屬性的GetHttpHandler方法可以得到最終被映射到當(dāng)前請求的HttpHandler對象。

對于ASP.NET MVC應(yīng)用來說,RouteData的RouteHandler屬性類型為MvcRouteHandler,實現(xiàn)在MvcRouteHandler中的HttpHandler提供機(jī)制基本上(不是完全等同)可以通過如下的代碼來體現(xiàn)。MvcRouteHandler維護(hù)著一個ControllerFactory對象,該對象可以在構(gòu)造函數(shù)中指定,如果沒有顯示指定則直接通過調(diào)用當(dāng)前ControllerBuilder的GetControllerFactory方法獲取。

public class MvcRouteHandler : IRouteHandler

{

    private IControllerFactory _controllerFactory;

    public MvcRouteHandler(): this(ControllerBuilder.Current

        .GetControllerFactory())

    { }

    public MvcRouteHandler(IControllerFactory controllerFactory)

    {

        _controllerFactory = controllerFactory;

    }

    IHttpHandler IRouteHandler.GetHttpHandler(RequestContext requestContext)

    {

        string controllerName = (string)requestContext.RouteData

            .GetRequiredString("controller");

        SessionStateBehavior sessionStateBehavior = _controllerFactory

            .GetControllerSessionrequestContext,  controllerName);

        requestContext.HttpContext.SetSessionStatesessionStateBehavior);< /p>

        return new MvcHandler(requestContext);

    }

}

在用于提供HttpHandler的GetHttpHandler方法中,除了返回一個實現(xiàn)了IHttpHandler接口的MvcHandler對象之外,還需要對當(dāng)前HTTP上下文的會話狀態(tài)行為模式進(jìn)行設(shè)置。具體的實現(xiàn)是:先通過包含在RequestContext的RouteData對象得到Controller的名稱,該名稱連同RequestContext對象一起傳入ControllerFactory的GetControllerSessionBehavior方法得到一個類型為SessionStateBehavior的枚舉。最后通過RequestContext得到當(dāng)前HTTP上下文(實際上是一個HttpContextWrapper對象),并調(diào)用其SetSessionStateBehavior方法對會話狀態(tài)行為進(jìn)行設(shè)置。

通過第2章“URL路由”的介紹我們知道,RouteData中的RouteHandler屬性最初來源于對應(yīng)的路由對象,而當(dāng)我們調(diào)用RouteCollection的擴(kuò)展方法MapRoute方法時注冊的Route對象對應(yīng)的RouteHandler是一個MvcRouteHandler對象。由于在創(chuàng)建MvcRouteHandler對象時并沒有顯式指定ControllerFactory,所以通過當(dāng)前ControllerBuilder的GetControllerFactory方法得到的ControllerFactory默認(rèn)被使用。

通過當(dāng)前ControllerBuilder的GetControllerFactory方法得到的ControllerFactory僅僅用于獲取會話狀態(tài)行為模式,而MvcHandler真正將它用于創(chuàng)建Controller。如下的代碼片段基本上體現(xiàn)了MvcHandler的定義,它對請求處理的邏輯定義在BeginProce***equest方法中。

public class MvcHandler : IHttpAsyncHandler, IHttpHandler, IRequiresSessionState

{

    //其他成員

    public RequestContext RequestContext { get; private set; }

    public bool IsReusable

    {

        get { return false; }

    }

    public MvcHandler(RequestContext requestContext)

    {

        this.RequestContext = requestContext;

    }

    IAsyncResult BeginProce***equest(HttpContext context, AsyncCallback cb,

        object extraData)

    {

        IControllerFactory controllerFactory =

            ControllerBuilder.Current.GetControllerFactory();

        string controllerName =

            this.RequestContext.RouteData.GetRequiredString("controller");

        IController controller = controllerFactory

            .CreateController(this.RequestContext, controllerName);

        if (controller is IAsyncController)

        {

            try

            {

                //調(diào)用BeginExecute/EndExecute方法以異步的方式執(zhí)行Controller

            }

            finally

            {

                controllerFactory.ReleaseController(controller);

            }

        }

        else

        {

            try

            {

                //調(diào)用Execute方法以異步的方式執(zhí)行Controller

            }

            finally

            {

                controllerFactory.ReleaseController(controller);

            }

        }

    }

}

由于MvcHandler同時實現(xiàn)了IHttpHandler和IHttpAsyncHandler接口,所以它總是以異步的方式被執(zhí)行(調(diào)用BeginProce***equest/EndProce***equest方法)。BeginProce***equest方法通過RequestContext對象得到目標(biāo)Controller的名稱,然后利用當(dāng)前ControllerBuilder創(chuàng)建的ControllerFactory激活Controller對象。如果Controller類型實現(xiàn)了IAsyncController接口,則以異步的方式執(zhí)行Controller,否則采用同步執(zhí)行方式。在被激活Controller對象被執(zhí)行之后,MvcHandler會調(diào)用ControllerFactory的ReleaseController對其進(jìn)行釋放清理工作。

以上是“Controller激活與URL路由的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI