IIS7.0中的Web應用程序有兩種配置模式:經典模式和集成模式。經典模式是為了與之前的版本兼容,使用ISAPI擴展來調用ASP.NET運行庫,
原先運行於IIS6.0下的Web應用程序遷移到IIS7.0中只要將應用程序配置成經典模式,代碼基本不用修改就可以正常運行。集成模式是一種統
一的請求處理管道,它將ASP.NET請求管道與IIS核心管道組合在一起,這種模式能夠提供更好的性能,能夠實現配置和管理的模塊化,而且
增加了使用托管代碼模塊擴展IIS時的靈活性。如果老的Web應用程序運行於IIS7.0的集成模式下,可能需要對應用程序的web.config文件進
行修改,尤其是使用了實現IHttpHandler接口的自定義模塊的情況。IIS7.0在同一個服務器上能夠同時支持兩種模式的應用程序。
IIS6.0中ASP.NET MMC管理單元用於配置ASP.NET,7.0中ASP.NET應用程序的管理域IIS管理更加緊密的集成在一起,不存在單獨的管理單
元,所有的IIS和ASP.NET配置都是使用IIS管理器完成的。IIS7.0配置信息基於.NET Framework配置系統,所以IIS7.0中運行的應用程序的
web.config文件同時包含web服務器和ASP.NET配置設置,例如可以再web.config文件中設置擴展名和文件的映射(IIS6.0中必須在IIS中進行
配置)。
web.config文件的變化
system.webServer節指定了應用於web應用程序的IIS7.0設置,其父節點是configuration,該節點中可以設置的內容包括:
• 當請求未包含指定資源時,Web服務器返回給客戶端的默認文檔(defaultDocument);
• 響應的壓縮設置(httpCompression)
• 自定義頭部(httpProtocol節的customHeaders)
• 模塊(modules)
• 處理程序(handlers)
其中的一些設置僅適用於集成模式,而不適用於經典模式,如經典模式下運行的應用程序則忽略web.config的system.WebServer節中指
定的所有托管代碼模塊和處理程序,這種模式下web應用程序應該在syste.web節的httpModules和httpHandlers中定義模塊和處理程序。
將 Web 應用程序遷移到集成模式
不包含自定義模塊或處理程序的 Web 應用程序通常無需更改即可在 IIS 7.0 集成模式下正常工作。對於依賴於自定義模塊或處理程序
的 Web 應用程序,需要執行以下步驟來使其能夠在集成模式下運行:
• 使用本主題稍后的將 Web Config 文件遷移到集成模式部分中描述的方法之一,在 Web.config 文件的 system.webServer 節中注
冊自定義模塊和處理程序。
• 僅在自定義模塊的 Init 方法中定義 HttpApplication 請求管道事件(如 BeginRequest 和 EndRequest)的事件處理程序。
• 請確保您已解決 Upgrading ASP.NET Applications to IIS 7.0: Differences between IIS 7.0 Integrated Mode and Classic
mode(將 ASP.NET 應用程序升級到 IIS 7.0:IIS 7.0 集成模式和經典模式之間的區別)的“Known Differences Between Integrated
Mode and Classic Mode”(集成模式和經典模式之間的已知區別)部分中討論的問題。
實現 IHttpModule 接口的模塊被稱為托管代碼模塊,因為它們是使用 .NET Framework 生成的。可以在服務器級別或應用程序級別注冊
托管代碼模塊。本機代碼模塊是僅在服務器級別注冊的 DLL(非托管代碼)。在集成模式下,將以托管模塊的形式實現核心 ASP.NET 功能,
例如會話狀態和 Forms 身份驗證。
在將應用程序從經典模式遷移到集成模式時,可以保留經典模式下的自定義模塊和處理程序注冊,也可以將這些注冊移除。如果不移除經典
模式下使用的 httpModules 和 httpHandlers 注冊,則必須將 validation 元素的 validateIntegratedModeConfiguration 屬性設置為
false 以避免錯誤。validation 元素是 system.webServer 元素的子元素。有關更多信息,請參見 ASP.NET Integration with IIS 7.0(
將 ASP.NET 與 IIS 7.0 集成)中的“Disabling the migration message”(禁用遷移消息)部分。
遷移 Web.config 文件以便在集成模式下使用
如果模塊或處理程序是在應用程序級別定義的,則不會自動調用該模塊或處理程序。這涉及符合以下條件的模塊或處理程序:在 Bin 文
件夾下的程序集中定義;在 App_Code 文件夾下作為源代碼定義;沒有在 Web.config 文件的 system.webServer 節中注冊和定義。為了使
模塊或處理程序能夠參與集成模式請求管道,必須使用下列方法之一注冊該模塊或處理程序:
• 直接編輯 Web.config 文件,並且將 modules 或 handlers 元素添加到 system.webServer 元素中。請注意,與經典模式相比,元
素名稱是不同的:modules 和 handlers 分別對應於經典模式下的 httpModules 和 httpHandlers。
• 使用 IIS 管理器配置模塊或處理程序。有關更多信息,請參見 Configuring Handler Mappings in IIS 7.0(在 IIS 7.0 中配置
處理程序映射)和 Configuring Modules in IIS 7.0(在 IIS 7.0 中配置模塊)。
• 使用 IIS 7.0 命令行工具 (Appcmd.exe)。有關更多信息,請參見 Configure Settings for a Site, Application, Virtual
Directory or URL by Using Appcmd.exe(使用 Appcmd.exe 配置站點、應用程序、虛擬目錄或 URL 的設置)。
使用集成模式的類和屬性
在 IIS 7.0 集成模式以及 .NET Framework 3.0 版或更高版本中使用應用程序時,可以使用下面這些在經典模式下不可用的類和成員:
• HttpResponse 對象的 SubStatusCode 屬性,使用它可以設置在配置了失敗請求跟蹤的情況下有用的代碼。有關更多信息,請參見
Troubleshooting Failed Requests Using Failed Request Tracing in IIS 7.0(使用 IIS 7.0 中的跟蹤功能解決請求失敗的問題)。
• HttpResponse 對象的 Headers 屬性,使用它可以訪問響應頭。
• HttpContext 對象的 IsPostNotification 和 CurrentNotification 屬性,在提供 HttpApplication 事件的處理程序時可以使用
它們。
• HttpRequest 對象的 Headers 和 ServerVariables 屬性,它們支持寫功能。
IIS 7.0下載(微軟Web服務器組件IIS 7.0):http://download.microsoft.com/download/1/0/d/10da04bb-4e82-485a-abb3-
94feff40a7b3/NETShow56_300.EXE