程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> .NET網頁編程 >> ASP.NET >> 關於ASP.NET >> 重提URL Rewrite(1):IIS與ASP.NET

重提URL Rewrite(1):IIS與ASP.NET

編輯:關於ASP.NET

之前覺得這個話題已經被談濫了。URL Rewrite早已經被廣大開發人員所接受,網上關於URL Rewrite的組件和文章也層出不窮,但是總是讓我感覺意猶未盡,於是最終還是忍不住提筆寫了這系列文章。這些文章不會談論URL Rewrite的價值與意義,而只會談論純技術的內容。文章中也不會有詳盡地實現分析,而是結合了我的經驗,從應用角度來講解這個話題。您已經知道的,您還不知道的,別處已經講過的,或者還沒有講過的,希望這系列文章的“舊事重提”不會讓您覺得沉悶,並且能讓您了解ASP.NET中URL Rewrite的方方面面。如果您以後再遇到URL Rewrite方面的問題是能夠想到這幾篇文章,估計我做夢也會笑出聲來。

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

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

IIS收到請求。

選擇器根據URL的特點與IIS中的配置,選擇一個ISAPI用於處理該請求——現在自然會選擇ASP.NET ISAPI。

ASP.NET執行引擎接收到請求,於是初始化數據(例如構建各種對象)。

開始觸發各種Pipeline事件,自然先從BeginRequest開始。

經過了多個Pipeline事件,ASP.NET根據配置為當前請求選擇一個合適的Handler或HandlerFactory進行處理(當然特殊情況例外,例如已經在之前的事件中直接輸出結果並結束請求了)。

經過了Handler處理之後又經過幾個Pipeline事件,以EndRequest結束。

輸出Response。

在一個ASP.NET應用中如果要進行URL Rewrite,那麼一般就是在BeginRequest事件中調用HttpContext的RewritePath方法,將該請求重新“定位”至一個目標URL。例如我們就可以在Global.asax中重寫Application_BeginRequest方法來實現這一點:

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved