從一個簡單的聊天程序SimpleChat看VPN技術
SimpleVPN寫好了以後,感覺比較簡單,我覺得只有簡單的東西才經得起折騰,才能全民折騰,所以說SimpleVPN還不夠簡單,本文來一個更加簡單的——展示一個超級簡單的點對點聊天程序,而且還帶簡單加密。順便,我們再來看下,到底什麼是VPN以及怎樣實現它。
QQ如今才剛剛行過成年之禮,典型的90後00前,卻早已到了後浪把前浪拍到岸邊的砍兒,果不其然,被10後的微信給逆襲了。好在都是騰訊的,這就把競爭收斂到了公司內部,不然這將意味著一個巨人的倒下,太可怕了。多年前,很多人逆向過QQ的協議,然後做了各種各樣的第三方客戶端,這在騰訊看來是在搞根據地搶飯碗,這是無法接受的,所以加強了各種安全措施,讓你第三方無法接入這個私有化的QQ系統。此後,第三方的QQ軟體漸漸消失了,只剩下了「騰訊QQ」。不過,在我看來,騰訊封閉QQ協議不見得是件好事,你能指望一個QQ終端能做出什麼大動作呢?充其量騰訊QQ是一個非常棒的產品,但是微信出來之後呢?如果微信不是T家的呢...所以說啊,讓所有人都接受T家的通訊協議才是真正的霸道,從業務側不一定是這般,至少從網路側看是這樣的。這樣一來,即便哪天阿里做出了新的社交產品,還是「基於騰訊的XXX協議,兼容QQv..版本,兼容微信v...版本」,你看那些偉大的公司,很多都貢獻了一個協議或者規範,比如HTTP、HHTPS、SSL/TLS、Android……
除了QQ之外,還有一類軟體是我們熟悉的,那就是迅雷和電驢。不管是QQ,還是迅雷、電驢,它們的共同點都是在TCP/IP網路之上重新構建了一個新的點對點網路,即P2P網路。所謂的P2P網路指的是網路中的節點都是對等關係,任意兩個節點之間,一個節點和多個節點之間均可以對等通信。事實上,P2P根本就沒有什麼神奇的,我們最底層的IP網路就是一個P2P網路,任意兩個節點之間都可以實現沒有主從關係的單播通信,而一個節點和多個節點之間則可以用組播進行通信,只是IP名稱早已有之,因此P2P就特指應用層的組網模式了。簡單點說,如果說IP網路是在各種互通的鏈路層之上構建的一個點對點網路的話,那麼P2P網路就是構建於TCP/IP之上的對點對網路。至於說這個點對點上跑什麼,那就取決於網路構建者的意願了。
如果在點對點網路上跑人與人之間互發的消息,那它就是個聊天軟體,比如QQ,微信這種,如果在點對點網路上跑文件數據,那就是P2P下載,那它就是個P2P下載軟體,比如迅雷,電驢這種,類似的,如果在點對點網路上跑IP數據報文或者以太幀,那它就是個Overlay技術,比如VXLAN、GRE這種,如果將以上這些Overlay數據進行加密,那它就是VPN。不管怎樣,名稱並不重要。
以上這些都不是本文的核心——本文的核心在於展示一下從VPN到聊天程序的過渡是多麼簡單。
用戶登錄可以獲取在線用戶列表;
用戶登錄後可以通知其它在線用戶該用戶登錄;
登錄用戶可以隨時獲取在線用戶列表;
登錄用戶可以給指定在線用戶發送消息;
支持在線用戶間的群聊。
基本上,除了不支持留言,基本該有的都有了。我們來看下怎麼改。
其實,TCP/IP任何層的對等通訊都是在「聊天」,只是類似社交軟體中的聊天是在人與人之間進行的,而TCP/IP對等層「聊天」是協議與協議之間進行的。協議與協議之間的聊天需要一個定址的過程,不管是DNS,IP路由,ARP解析,MAC/埠查找...都是為了確認並找到要把消息發給誰。而人與人之間的聊天在發消息之前也要在頭腦中經過一個類似的過程,也就是說,當你按下回車鍵的那一刻,你已經很明確這條消息是發給誰的了,這與網路協議之間的對等通信完全不同,後者需要協議來完成定址,而人則在自己的大腦中完成定址過程,所以說,改法很簡單:
1. 添加消息的發送和接收
chat程序直接接收用戶的輸入,而不是從TAP中讀取以太幀,所以不需要tap_fd,改為con_fd了,其實就是console,因此需要將read_from_tap和write_to_tap改為
read_from_console和write_to_console:
2. 刪除定址和學習機制
由於定址已經在人的大腦中完成,故不再需要定址,因此去掉了以下的handler:
3. 增加在線用戶列表顯示功能
詳見1的用戶輸入解析。當輸入list的時候,會顯示在線用戶。
現假設有ID為1,2,3的3個用戶登錄系統,用戶3輸入list時,以下是輸出:
ID:1 online
ID:2 online
然後同樣在用戶3的終端前輸入2:aaaaaaaaaaaaaaaa,那麼用戶2的終端將顯示:
From 3:aaaaaaaaaaaaaaaa
也許你會覺得這不像個聊天程序,那是因為它少一個漂亮的GUI,而我並不擅長這個。
------------------------
此時應該知道frame中sid,did這兩個ID的作用了,它可以用來支持群聊,就跟它在VPN中支持組播一樣...
關於這個的代碼,我已經放進了github的SimpleVPN那個目錄:https://github.com/marywangran/SimpleVPN/blob/master/SimpleChat.c
通過以上,我們可以看出,這類技術可以改頭換面叫做任何不同的名稱,關鍵還是看你怎麼用它了。不管它叫VPN,管它叫chat,管它叫overlay吧,或者直接overlaychat。
其實,要什麼VPN,如果你和你的QQ好友能把自己的QQ輸入輸出和本地的一個TAP網卡字元設備的輸入輸出對接起來,那大QQ就可以當成是一個VPN客戶端,同樣的,如果你用迅雷,電驢什麼的來對接一個虛擬網卡傳輸以太幀或者IP報文而不是傳輸文件,那麼迅雷,電驢構建出來的P2P網路就是一個VPN網路。
讓我們來暢想一下如何來應景。在裝了QQ的Windows機器上,有一個文件,它是「C:/Tap.frame」,針對它的讀寫實際上就是在讀寫TAP虛擬網卡設備,這個用Windows驅動非常容易辦到。此時,我們把這個文件用QQ傳送給好友,並且好友那邊也有一個這樣的文件,會怎樣?我們豈不是通過QQ搭建了一條隧道嗎?Overlay?嗯,是的,這叫做IP over QQ吧,或者Everything over APP?管它呢,名詞不重要!
這是分層模型給我們帶來的好處!只要你的IP報文或者以太幀在本地形成了,除了直接發送到網線上之外,還有別的運輸方式,比如你可以用UDP將其送出,可以用一個新的IP,當然這些都是常規的。本文中,我們看到,你還可以用QQ、迅雷、電驢之類的軟體將其送出,甚至,你可以用集裝箱將其送出,這就是IP over集裝箱技術。
本文來自CSDN博客:


TAG:CSDN |
※Spring Boot入門:第一個Spring Boot程序
※Adobe發布VR應用程序Project New View
※在 Kubernetes 上運行一個 Python 應用程序
※開獎+小程序抽籤丨Nike Air Presto Mid x ACRONYM?
※NextVR應用程序登陸Viveport平台支持Vive
※最新Magic Leap SDK集成了Runtime,允許多程序同時運行
※Playstation 4 加推 iOS 平台 Remote Play 應用程序
※VNote:一個更懂程序員和 Markdown 的筆記軟體
※全方位看你的愛車Edmunds推出AR應用程序Can It Fit
※ScreenCloud:一個增強的截屏程序
※Google Podcasts vs.Pocket Casts 哪個播客應用程序適合你?
※亞馬遜將出售HTC Viveport應用程序並開放Prime Day VR體驗區
※Magic Leap One開發NAB專屬AR應用程序
※微軟 Visual Studio C+Runtime 安裝程序是失效的、垃圾的
※Meta推出AR 3C CAD可視化應用程序Meta Viewer
※開獎+小程序抽籤丨Nigel Sylvester x Air Jordan 1
※Best Western聯手IBM人工智慧程序Watson,打造個性化度假方案
※ndm:NPM 的桌面 GUI 程序
※開獎+小程序抽籤丨Nike Air Jordan 1 「Court Purple」
※開獎+小程序抽籤丨 Air Jordan 1「No L』s」系列「Varsity Red」配色