Solo即時聊天軟件(聊天、文件傳輸、UDP的p2p打洞)
當前位置:點晴教程→知識管理交流
→『 技術(shù)文檔交流 』
solo開源代碼下載地址: 早就想寫個屬于自己的即時聊天軟件,現(xiàn)在總算擁有了!實現(xiàn)了文件(文件夾)傳輸、群聊、私聊、表情等。。 其他不多說,直接進入正題,把我的想法和感受和他家分享一下。 當然要做一個聊天軟件,首先要懂得網(wǎng)絡通信的基礎(chǔ)tcp\ip,udp之類的協(xié)議,還有socket編程。 其時間里兩臺電腦之間的通信是非常簡單的,對于udp是無連接的傳輸層協(xié)議,不像tcp那樣需要accept和connect什么的需要確保連接。但是udp又是不可靠的,但是相對來說,我覺得對于即時聊天軟件來說,使用udp還是足夠的。于是我采用了udp協(xié)議來貫穿我的軟件。當然一般的不加修飾的socket,只能實現(xiàn)同類網(wǎng)絡地址下的通信,對于一個不同內(nèi)網(wǎng)的計算機,將無法進行通信,這樣也大大局限了我們軟件的使用范圍,所以我采用了udp下的nat穿透技術(shù)來突破這一障礙,具體理論我們參照這篇文章http://xy.guet.edu.cn/xyzone/show/139。。 先談談整體的思想吧,這個即時聊天軟件是以c/s構(gòu)架的,服務器主要負責客戶的信息轉(zhuǎn)發(fā),當然只是客戶本身的ip、各種端口(消息監(jiān)聽,文件監(jiān)聽)、用戶名之類的屬性,他不直接參與客戶之間的通訊,只有當客戶之間需要nat穿透的時候才會通過服務器通知需要通信的一方向另一方發(fā)送“打洞”請求,另外還處理客戶之間的登錄和下線事件的廣播,所以服務器的壓力會比較小。 至于客戶端,我采用了傳統(tǒng)的聊天軟件的慣用方式,一個主對話框,顯示好友信息。出于減小難度,我只采用一個樹控件來控制這些好友信息,而沒有采用tab類型的控件,即使采用也是要花費一定的功夫去重寫這些控件類,才能滿足我們的要求。然后通過雙擊樹控件的子項來彈出聊天對話框,說到這里我不得不說一下c++的確是高處c一大籌,(封裝、繼承、多態(tài))這是在是太帥了。創(chuàng)建這些聊天對話框時,將傳入對應的客戶ip、對話框指針、用戶名(號碼)等以用來正確識別。主程序運行就掛起一個消息監(jiān)聽線程,來循環(huán)監(jiān)聽從不同客戶發(fā)來的消息,然后進行不同的處理,所以使用了較多的宏,吧來自不同客戶的消息傳給不同的本地聊天對話框處理,所以剛才說的在創(chuàng)建聊天對話框的時候的參數(shù)就非常重要了,處理不好可能會出現(xiàn)差錯。諸多細節(jié)在這里還是比較難以細說。雖然采用了udp傳輸協(xié)議,但是我通過消息回執(zhí)來確保消息發(fā)送成功,這個回執(zhí)將決定是否進行打洞處理。而在文件傳輸功能上的實現(xiàn),采用了tcp傳輸層協(xié)議(我也不知道為什么自己就選擇了這個,估計是但是第一感覺需要accept和connect),我是在主程序運行時就掛起一個文件監(jiān)聽線程,當然這個監(jiān)聽端口是在程序運行是,沒有登錄服務器之前就首先動態(tài)獲取的,我只是循環(huán)地查找沒有被占用的端口并綁定套接字。在有客戶發(fā)來文件傳送請求時,就創(chuàng)建一個文件接收和發(fā)送線程。感覺以上這些還是比較容易實現(xiàn)的。當然采用類的思想才會比較清晰,否則會比較亂。 再講講其他一些小小細節(jié),比如那個菜單的實現(xiàn),如果采用對話框的默認菜單,我們都會覺得比較惡心,的確有點難看,所以我把對話框的菜單欄卻掉了,然后添加了on_wm_nchittest()消息,實現(xiàn)無菜單的客戶區(qū)拖動,然后重寫個button類來實現(xiàn)png圖片的裝飾,實現(xiàn)鼠標經(jīng)過、懸停和按下的狀態(tài)(就像qq的最小化和關(guān)閉按鈕那樣的效果),當然,我使用的是vc6開發(fā)的,不能直接使用gdi+,所以配置了一下才行(具體方法自己網(wǎng)上一查就知道了)。然后那個對話框的主背景,也是通過把一張png圖片繪上去的,當然還要解決一些閃爍的問題,可以采用雙緩沖來解決。在做界面的時候,我深感自己缺乏藝術(shù)細胞,ps技術(shù)實在太爛,做的按鈕圖片比較難看,顏色搭配和漸變效果實在難以控制。而文件實現(xiàn)拖拽發(fā)送也比較簡單,增加個on_wm_dropfiles()消息函數(shù),對話框拓展屬性勾上accept file就好了,剩下的就是處理路徑的問題了,還有多個文件的同時拖拽問題。還有就是那個表情是比較難以處理的一個模塊,當時就調(diào)試了我一個星期才解決,為了添加表情功能,我不得不放棄原來使用的edit控件(由于以前都只是使用edit),使用了richedit控件,使用該控件還是有很多細節(jié)要處理的,比如初始化才能使用啊什么的,當然為了實現(xiàn)表情的功能,我還是得重新寫richedit這個類,拓展一下。因為我是使用轉(zhuǎn)義碼來實現(xiàn)的,每一個表情對應一個轉(zhuǎn)義碼,就像c語言中\(zhòng)n代表換行一樣。重寫的類中要實現(xiàn),文本的添加和當文本改變時要處理一些諸如是否寫入了轉(zhuǎn)義碼,超鏈接等等,至于那個表情布,只是一張小小的銀白色的圖片為底,然后再圖片上分出很多個小小的矩形來容納一個個小小的表情按鈕,很多按鈕吧,沒錯!每個小小的表情都是覆蓋在按鈕上的,同樣要實現(xiàn)鼠標經(jīng)過懸停和按下的事件,還得畫一下那個藍色的邊框。??傊@個表情功能的添加,我耗費較多的時間了,明白一點:微軟提供的控件都是令我們不夠滿意的,我們得自己重寫這些控件類,也就是繼承他?。。。。ㄓ浀帽4嫦聛硪院笤儆门叮?。 講到這里,這個即時聊天軟件的主要思想也介紹差不多了。。提幾點軟件開發(fā)的體會,要注意代碼的編寫習慣,不要寫那么多全局變量和外部變量(不到比不得以的話),注意內(nèi)存的釋放防止泄露,調(diào)試能力很重要(否則很多時候看卡你怎么不知所措)。 謝謝您的指點。 該文章在 2014/1/27 23:46:50 編輯過 |
關(guān)鍵字查詢
相關(guān)文章
正在查詢... |