溫馨提示×

溫馨提示×

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

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

ASP.NET中URL Rewrite的實(shí)現(xiàn)方法

發(fā)布時間:2021-10-28 09:15:24 來源:億速云 閱讀:131 作者:柒染 欄目:編程語言

今天就跟大家聊聊有關(guān)ASP.NET中URL Rewrite的實(shí)現(xiàn)方法,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結(jié)了以下內(nèi)容,希望大家根據(jù)這篇文章可以有所收獲。

之前覺得這個話題已經(jīng)被談濫了。URL Rewrite早已經(jīng)被廣大開發(fā)人員所接受,網(wǎng)上關(guān)于URL Rewrite的組件和文章也層出不窮,但是總是讓我感覺意猶未盡,于是最終還是忍不住提筆寫了這系列文章。這些文章不會談?wù)揢RL Rewrite的價值與意義,而只會談?wù)摷兗夹g(shù)的內(nèi)容。文章中也不會有詳盡地實(shí)現(xiàn)分析,而是結(jié)合了我的經(jīng)驗(yàn),從應(yīng)用角度來講解這個話題。您已經(jīng)知道的,您還不知道的,別處已經(jīng)講過的,或者還沒有講過的,希望這系列文章的“舊事重提”不會讓您覺得沉悶,并且能讓您了解ASP.NET中URL Rewrite的方方面面。如果您以后再遇到URL Rewrite方面的問題是能夠想到這幾篇文章,估計我做夢也會笑出聲來。

要充分理解文章后面談到的話題,我們必須簡單的了解一下IIS與ASP.NET的通信過程。我在這里講解的是IIS 6服務(wù)器。至于IIS 5和IIS 7,前者可以說已經(jīng)被淘汰了,而后者的“經(jīng)典模式”與IIS 6可謂如出一轍,而新的“管道模式”其實(shí)是講ASP.NET中的某些概念與IIS進(jìn)行了深度集成。我相信,如果您了解了IIS 6和ASP.NET,在IIS 7的集成模式下也不會有任何問題。

首先我們來看一幅簡單的示意圖,展示了IIS從收到Request開始,到返回Response整個過程中的幾個主要步驟:

ASP.NET中URL Rewrite的實(shí)現(xiàn)方法

1.IIS收到請求;

2.選擇器根據(jù)URL的特點(diǎn)與IIS中的配置,選擇一個ISAPI用于處理該請求——現(xiàn)在自然會選擇ASP.NET ISAPI;

3.ASP.NET執(zhí)行引擎接收到請求,于是初始化數(shù)據(jù)(例如構(gòu)建各種對象);

4.開始觸發(fā)各種Pipeline事件,自然先從BeginRequest開始;

5.經(jīng)過了多個Pipeline事件,ASP.NET根據(jù)配置為當(dāng)前請求選擇一個合適的Handler或HandlerFactory進(jìn)行處理(當(dāng)然特殊情況例外,例如已經(jīng)在之前的事件中直接輸出結(jié)果并結(jié)束請求了);

6.經(jīng)過了Handler處理之后又經(jīng)過幾個Pipeline事件,以EndRequest結(jié)束;

7.輸出Response。

在一個ASP.NET應(yīng)用中如果要進(jìn)行URL Rewrite,那么一般就是在BeginRequest事件中調(diào)用HttpContext的RewritePath方法,將該請求重新“定位”至一個目標(biāo)URL。例如我們就可以在Global.asax中重寫Application_BeginRequest方法來實(shí)現(xiàn)這一點(diǎn):

之所以在BeginRequest中進(jìn)行Rewrite,是因?yàn)檫@個事件是在所有Pipeline事件中最早被觸發(fā)的。在這時進(jìn)行了重新“定位”之后,當(dāng)前HttpContext中的一些屬性也就發(fā)生了相應(yīng)的變化(例如HttpContext.Request.Path)。這樣,接下來的Pipeline事件的處理程序邏輯就會受到影響。例如在需要根據(jù)目錄進(jìn)行權(quán)限判斷時,就會使用“定位”后的路徑,而不是ASP.NET所收到的請求。自然最“顯著”的變化就是對Handler的選擇,例如上例,我們把請求重新定位至“CustomerList.aspx”文件,這樣ASP.NET引擎就會選擇*.aspx所對應(yīng)的System.Web.UI.PageHandlerFactory類對請求進(jìn)行處理。

public class Global : System.Web.HttpApplication
{
    protected void Application_BeginRequest(object sender, EventArgs e)
    {
        HttpContext context = HttpContext.Current;
 
        if (context.Request.Path.Equals("/Customers",
            StringComparison.InvariantCultureIgnoreCase))
        {
            context.RewritePath("~/CustomerList.aspx");
        }
    }
}

***插句提外話,有兩個概念需要區(qū)分開來,那就是“ASP.NET Pipeline”與“Web Forms”。兩者都是ASP.NET里的重要模型,但是差別還是非常大的:

◆ASP.NET Pipeline:作為每個ASP.NET應(yīng)用所接受到的請求來說,都會經(jīng)過這個“管道”進(jìn)行處理。這是一個ASP.NET級別的模型。

◆Web Forms:在ASP.NET Pipeline的執(zhí)行過程中,其中有一個步驟是選擇一個合適的Handler(或HandlerFactory)來處理請求。如果是aspx頁面,ASP.NET就會選擇System.Web.UI.PageHandlerFactory類,在這個類中才最終形成了WebForms模型。

其實(shí)上面這句話的“形成”二字可能也不太確切。因?yàn)閃eb Forms可能應(yīng)該是一個可以獨(dú)立使用的執(zhí)行引擎和模型,而System.Web.UI.PageHandlerFactory中也只是利用了這個模型而已。我們在編寫ASP.NET應(yīng)用時,完全可以根據(jù)我們的需要,在其他地方使用這個模型。

看完上述內(nèi)容,你們對ASP.NET中URL Rewrite的實(shí)現(xiàn)方法有進(jìn)一步的了解嗎?如果還想了解更多知識或者相關(guān)內(nèi)容,請關(guān)注億速云行業(yè)資訊頻道,感謝大家的支持。

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

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

AI