WCF擴展點在自定義運行時使用
WCF開發工具中具有許多比較突出的優勢特點,這也決定了它在開發領域中所占據的主導地位。在這里,我們將會為大家詳細介紹一下有關WCF擴展點的相關應用方式,以幫助大家掌握這一工具的應用。#t#
Communication Foundation (WCF) 提供了許多WCF擴展點,供開發人員自定義運行時行為,從而實現服務調度和客戶代理調用。您可以通過編寫能以聲明方式應用到服務中的自定義行為來使用這些擴展點。
WCF 在通道層的頂部還提供了一個高級運行時,主要是針對應用程序開發人員。在 WCF 文檔中,它常被稱為服務模型層。該高級運行時主要由一個稱作調度程序(在服務主機上下文中)的組件和一個稱作代理(在客戶端上下文中)的組件組成。
調度程序/代理組合的主要作用是在 WCF 消息對象和 .NET Framework 方法調用間進行轉換)。這些組件按照一系列明確定義的步驟來執行此過程,并在此過程的每個步驟中都提供了可供插入的擴展點。您可以使用這些擴展點來實現各種自定義行為,包括消息或參數驗證、消息日志記錄、消息轉換、自定義序列化/反序列化格式、輸出緩存、對象共用、錯誤處理和授權等.
1.調度程序/代理擴展
調度程序和代理都提供了大量的WCF擴展點,您可以在其中插入自己的代碼;這些擴展常被稱為偵聽器,因為它們允許您偵聽默認的運行時執行行為。不過,我通常稱它們為運行時擴展。
顯示了客戶端代理體系結構及可用的擴展點。代理的主要作用是將調用方提供的對象(參數)轉換為 WCF 消息對象,然后將后者提供給底層通道堆棧進行網絡傳輸。
可以通過 ClientOperation 和 ClientRuntime 對象在代理上配置這些擴展。您可以找到一個用于各種服務操作的 ClientOperation 對象和一個用于從整體上配置代理的 ClientRuntime 對象。ClientOperation 提供了用于管理參數檢查和消息格式化擴展的屬性,而 ClientRuntime 則提供了用于管理消息檢查擴展的屬性。
當調度程序收到來自通道堆棧的 Message 對象時,遇到的第一個擴展點便是消息檢查。然后,調度程序必須選擇一個要調用的操作(步驟 2),然后才能繼續 — 這里有一個擴展點用于覆蓋默認的操作選擇行為。確定目標操作后,調度程序會將消息反序列化為調用目標方法時可作為參數提供的對象。此時(步驟 3),調度程序提供用于進行消息格式化(反序列化)和參數檢查(步驟 4)的擴展點。調度程序的最后一步是調用提供就緒參數的目標方法。您甚至可以通過提供自定義的操作調用程序對象來替代這一步。
可以通過 DispatchRuntime 和 DispatchOperation 對象在調度程序上配置這些擴展。稍后我將簡要介紹如何訪問這些對象,不過,首先讓我們討論一下如何實現它們。
2 實現自定義擴展
上述的每個WCF擴展點都是根據 .NET 接口定義來模擬的。注意,在某些情況下,相同的邏輯擴展類型要求在調度程序和代理端之間使用另一接口。下面我將詳細介紹如何實現其中的部分接口。
消息檢查器
不管是什么操作,假設您要檢查的是流入和流出服務的消息,而不是參數。在這種情況下,您需要使用消息檢查WCF擴展點。與參數檢查不同,此時用于調度程序和代理(分別是 IDispatchMessageInspector 和 IClientMessageInspector)的消息檢查接口是不同的。不過,當需要支持兩端時,始終可以實現這兩個接口。
IDispatchMessageInspector 有兩個方法:AfterReceiveRequest 和 BeforeSendReply,這樣您就有前偵聽點和后偵聽點來檢查 WCF 消息對象了。IClientMessageInspector 還有兩個提供相反點的方法:AfterReceiveReply 和 BeforeSendRequest。