|
1. 有關生存期的補充
正常情況下,每次調用 WebMethod,服務器都會創建一個新的 WebService 對象,即便客戶端使用同一個代理對象多次調用 WebMethod。而我們一旦調用了有緩存標記的 WebMethod,只要未超出緩存期,WebService 對象都不會被重新創建。在緩存期內調用沒有緩存標記的 WebMethod,也會繼續使用該 WebService 對象。有太多因素讓這個緩存機制變得不那么可靠,因此我們不能奢望用緩存標記來維持特定的對象狀態,況且緩存機制的設計初衷也只是為了快速輸出那些比較穩定非常大的數據。
基于多用戶并發調用這個環境,WebService 本身最好設計成無狀態對象,我們可以使用 Session 和 Application 來保持特定的狀態信息。
2. 異步調用
網上很多人在寫有關 .NET 2.0 的文章時,都喜歡用“優雅”這個詞。的確,在 2.0 中編譯器和代碼生成器為我們封裝了很多羅嗦的東西,諸如匿名方法、委托推斷等等,當然還有這 WebService 的異步調用。我們不用再寫那些個 BeginXXX、EndXXX 了,基于事件驅動的異步機制會自動為每個 WebMethod 生成一個 XXXAsync 的異步方法和 XXXCompleted 事件,我們只需調用該方法,并處理該事件即可完成異步操作,當真是優雅了不少。不要小看 2.0 的這些封裝,我們編寫的代碼越少意味著出錯的幾率越小。
下面的示例中,我們使用了匿名方法來處理事件,看上去更簡潔了些。

WebServices.cs
[WebService(Namespace = "http://www.rainsts.NET/", Description="我的Web服務")]
[WebServiceBinding(ConformsTo = WsiProfiles.BasicProfile1_1)]
public class WebService : System.Web.Services.WebService
{
[WebMethod]
public string HelloWorld()
{
return "Hello World!";
}
}
Client.cs
WebService ws = new WebService();
ws.HelloWorldCompleted += delegate(object sender, HelloWorldCompletedEventArgs e)
{
Console.WriteLine(e.Result);
};
ws.HelloWorldAsync("xxx");
it知識庫:簡單的web WebService安全,轉載需保留來源!
鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。