1. 程式人生 > >C#遠程調用技術WebService葵花寶典

C#遠程調用技術WebService葵花寶典

安全 規則 hyper 方法 gin 包括 net 模式 學習

一、課程介紹

直接開門見山吧,在學習之前阿笨想問大家一句,關於WebService遠程過程調用技術(RPC) 你真的會了嗎?不要跟老夫扯什麽WebService技術已經過時,如果你的內心有在偷偷告訴你其實我是真的不會WebService的話,那麽恭喜你,因為你在這茫茫的IT編程世界裏找到了這本《C#遠程調用技術WebService葵花寶典》!曾經有一位不知名的講師說過這麽一句名言: 一門RPC技術不會,那麽千萬萬門RPC技術將都不會!

本次阿笨的分享課包含以下知識點。

1、C# WebService常用的幾種調用方式。

2、WebService如何使用異步調用。(基於異步委托BeginInvoke/EndInvoke、基於委托事件機制、基於Async Task異步編程模式)

3、C# WebService如何保證客戶端以安全的方式進行訪問。

4、C#通過反射(Reflection)動態創建WebService實例。

5、微軟的輕量級的IOC框架Unity的基本使用。

在此插播一條硬廣告:下一堂分享課程阿笨計劃將給大家帶來《C#面向服務編程技術WCF從入門到實戰演練》

如果您對本次分享課感興趣的話,那麽請跟著阿笨一起學習吧。廢話不多說,直接上幹貨,我們不生產幹貨,我們只是幹貨的搬運工。

二、C# WebService兩種不同引用使用方式

2.1、Web References方式引用。

2.2、Service References方式引用。

三、C# WebService如何使用異步調用

3.1、基於異步委托BeginInvoke/EndInvoke。

3.2、基於委托事件的Event機制。

3.3、基於Async Task 異步編程模型。

四、C# WebService如何保證客戶端以安全的方式進行訪問

4.1、先說話一下何為安全?我們需要解決什麽問題?

調用安全:由於WebService是暴露在公網中,怎麽防止非法用戶調用我們的服務呢?因此我們需要解決:授權問題。

數據傳輸安全:由於我們的數據都是通過密文在網絡上進行傳輸很容易被竊取到。因此我們需要解決:數據被竊取問題。

以上解釋僅僅是阿笨狹義的理解;網絡安全還包括很多方面,會話劫持、會話被篡改等等。

4.2、阿笨分享一下目前的幾種常用的解決方案。

1、WebService每一個方法都需要傳遞一個Token固定的參數,不同的調用者各自的Token值不一樣。服務端有一套規則算法生成Token值,將這個值持久化在關系數據庫或者文件以及內存數據庫中。

2、WebService采用asp.net的認證機制。常見的認證方式有:FORM身份驗證、集成WINDOWS驗證、Basic基礎認證、 Digest摘要認證、

3、WebService采用SSL實現加密傳輸。

HTTPS(全稱:Hyper Text Transfer Protocol over Secure Socket Layer)安全傳輸協議。(強烈推薦)

4、通過WebService給我們提供的SoapHeader來實現用戶身份驗證。(強烈推薦)

阿笨將實戰環節給大家分享一種優雅的方式進行針對WebService身份驗證。

5、以上幾種解決方案進行組合使用。(個人推薦使用:③+④兩個方案進行組合使用)(強烈推薦)

總結:我們可以通過SoapHeader來保證WebService的授權使用;可以通過SSL來保證數據的加密,防止網絡偵聽!

五、C# WebService如何采用SoapHeader進行身份驗證

技術分享
WebService身份驗證

六、C# WebService如何通過優雅的方式進行統一入口調用

6.1、Unity容器方式獲取WebService服務實例。

6.2、Reflect反射方式獲取WebService服務實例(推薦使用)。

C#遠程調用技術WebService葵花寶典