一、課程介紹 直接開門見山吧,在學習之前阿笨想問大家一句,關於WebService遠程過程調用技術(RPC) 你真的會了嗎?不要跟老夫扯什麼WebService技術已經過時,如果你的內心有在偷偷告訴你其實我是真的不會WebService的話,那麼恭喜你,因為你在這茫茫的IT編程世界里找到了這本《C# ...
一、課程介紹
直接開門見山吧,在學習之前阿笨想問大家一句,關於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服務實例(推薦使用)。