亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? 17.htm

?? VB的一些網絡編程的例子,個人認為還不錯。大家一起來研究一下.
?? HTM
字號:
<p>編寫網絡尋呼機   </p>
<p>作者:岳兵</p>
<p></p>
<p>  提起ICQ的大名,愛好電腦的朋友一定不會感到陌生的吧?ICQ就是互聯網上的尋呼機,無論什么時候,只要你的朋友在線,你只需在ICQ中輸入他的ID號碼,你就可以在互聯網上呼到他。ICQ由于其方便、快捷,且擁有眾多的注冊用戶而一舉成為互聯網上最流行的網絡尋呼機,它幾乎成為每一個上網用戶的必備之物。當你在使用ICQ的時候,是否會想過自己動手編寫一個網絡尋呼機呢?這其實在VB中就可以實現。</p>
<p></p>
<p>  網絡尋呼的原理就是當客戶端程序連接服務器時,通過服務器搜索所要呼叫的ID號碼,如果檢測到此用戶且該用戶正處于聯網狀態,則服務器通知此用戶的客戶端程序響應主叫方客戶端程序,然后在主叫方和被叫方建立連接后,雙方就可以聊天或進行其它的通信。</p>
<p></p>
<p>  在VB中編寫網絡尋呼機需要建立兩個程序,一個為客戶端程序Client,一個為服務器端程序Server。</p>
<p></p>
<p>  一、在Client工程中建立一個窗體,加載WinSock控件,稱為tcpClient,協議選擇TCP。再加入四個文本框,用以輸入服務器的IP地址、服務器端口號,被呼叫的網絡尋呼ID號以及用戶登錄ID號。然后再在窗體中加入三個按鈕,分別命名為“連接”、“斷開”和“退出”,點擊“連接”按鈕,并進行如下初始化連接,代碼如下: </p>
<p></p>
<p>Private Sub Command1_Click()</p>
<p> If Len(Text1.Text) = 0 And Len(Text2.Text) = 0 Then</p>
<p>  MsgBox ("請輸入主機名或主機IP地址。")</p>
<p>  Exit Sub</p>
<p> ElseIf Len(Text1.Text) > 0 Then</p>
<p>  tcpClient.RemoteHost = Text1.Text</p>
<p>  tcpClient.RemotePort = Text2.Text</p>
<p> End If</p>
<p> tcpClient.Connect</p>
<p> Timer1.Enabled = True</p>
<p>End Sub</p>
<p></p>
<p>Private Sub Command2_Click()</p>
<p> tcpClient.Close   '斷開連接</p>
<p>End Sub</p>
<p></p>
<p>Private Sub Command3_Click()</p>
<p> End</p>
<p>End Sub</p>
<p></p>
<p>Private Sub Form_Load()</p>
<p> Text2.Text = "1001"</p>
<p>End Sub</p>
<p></p>
<p>Private Sub tcpClient_Connect()</p>
<p> tcpClient.SendData (Text3.Text&"@"&Text4.Text)</p>
<p>End Sub</p>
<p></p>
<p>Private Sub tcpClient_DataArrival(ByVal bytesTotal As Long)</p>
<p> Dim strData As String</p>
<p> tcpClient.GetData strData</p>
<p> strData = strData + "呼叫" </p>
<p>'在收到呼叫消息后彈出一對話框并顯示主叫方ID號碼</p>
<p> MsgBox (strData)</p>
<p>End Sub</p>
<p></p>
<p>  二、在服務器端Server工程中也建立一個窗體,加載WinSock控件,稱為tcpServer,協議選擇TCP,設置其Index值為0,并在工程中添加模塊。內容如下: </p>
<p></p>
<p>Private Type ActiveUser</p>
<p> ClientIP As String    '記錄客戶的IP地址</p>
<p> ClientPort As Integer  '記錄當前會話的端口</p>
<p> ClientID As Long     '記錄客戶的ID號碼</p>
<p> ClientConnected As Boolean '客戶連接狀態,True表示已連接,False表示沒有連接</p>
<p>End Type</p>
<p></p>
<p>Dim CurUser() As ActiveUser</p>
<p>Dim tcpIndex As Integer  '跟蹤當前建立連接數</p>
<p></p>
<p>  在Form_Load事件中加入如下代碼: </p>
<p></p>
<p>Private Sub Form_Load()</p>
<p> tcpServer(0).Protocol = sckTCPProtocol</p>
<p> tcpServer(0).LocalPort = 1001 </p>
<p> '將 LocalPort 屬性設置為一個整數。</p>
<p> tcpServer(0).Listen  '然后調用 Listen 方法。</p>
<p> tcpIndex = 1</p>
<p>End Sub</p>
<p></p>
<p>  準備應答客戶端程序的請求連接,使用ConnectionRequest事件來應答戶端程序的請求,代碼如下: </p>
<p></p>
<p>Private Sub tcpServer_ConnectionRequest(Index As Integer, ByVal requestID As Long)</p>
<p> Dim i As Integer</p>
<p> On Error GoTo ErrHandle</p>
<p> For i = 1 To tcpIndex  '選擇一個空閑端口</p>
<p>  If CurUser(i).ClientConnected = False And i < > tcpIndex Then</p>
<p>   Load tcpServer(i)</p>
<p>   tcpServer(i).LocalPort = CurUser(i).ClientPort - 1</p>
<p>   tcpServer(i).Accept requestID</p>
<p>   Exit For</p>
<p>  ElseIf CurUser(i).ClientConnected = False Then</p>
<p>    Load tcpServer(i)</p>
<p>    tcpServer(i).LocalPort = Port</p>
<p>    If tcpServer(i).State < > sckClosed Then</p>
<p>     tcpServer(i).Close</p>
<p>    End If</p>
<p>    tcpServer(i).Accept requestID</p>
<p>    Exit For</p>
<p>  End If</p>
<p> Next</p>
<p> DoEvents</p>
<p> '測試連接是否成功</p>
<p> If tcpServer(i).State = sckConnected Then</p>
<p>  If i = tcpIndex Then   </p>
<p>   '已經沒有可用端口,記錄客戶的IP地址和端口號</p>
<p>   tcpIndex = tcpIndex + 1</p>
<p>   Port = Port + 1</p>
<p>   ReDim Preserve CurUser(tcpIndex)</p>
<p>   CurUser(i).ClientIP = tcpServer(i).RemoteHostIP</p>
<p>   CurUser(i).ClientConnected = True</p>
<p>   CurUser(i).ClientPort = Port</p>
<p>   CurUser(tcpIndex).ClientConnected = False</p>
<p>  Else</p>
<p>   CurUser(i).ClientIP = tcpServer(i).RemoteHostIP</p>
<p>   CurUser(i).ClientPort = Port</p>
<p>   CurUser(i).ClientConnected = True</p>
<p>  End If</p>
<p> End If</p>
<p> Exit Sub</p>
<p> ErrHandle:</p>
<p>  Resume Next </p>
<p>  '檢查控件的 State 屬性,如未關閉,在接受新的連接之前關閉此連接。</p>
<p>  If tcpServer(0).State <> sckClosed Then</p>
<p>  tcpServer(0).Close</p>
<p>  tcpServer(0).Accept requestID  </p>
<p>  '接受具有 requestID 參數的,連接。</p>
<p>End Sub</p>
<p></p>
<p>Private Sub tcpServer_DataArrival(Index As Integer, ByVal bytesTotal As Long)</p>
<p> Dim i As Integer</p>
<p> Dim s As String</p>
<p> Dim RequID As Long  '主叫方ID號碼</p>
<p> Dim SearchID As Long '被叫方ID號碼</p>
<p></p>
<p> On Error GoTo ErrHandle</p>
<p> tcpServer(Index).GetData s, vbString </p>
<p> '接收數據并存入s   </p>
<p> If Mid(s, i, 1) = "@" Then </p>
<p>  '分離s中的主叫方和被叫方ID號碼</p>
<p>  SearhID = Left(s, i - 1)  '把號存入mKey</p>
<p>  RequID = Right(s, Len(s) - i) 'ID存入RequID</p>
<p> End If</p>
<p></p>
<p> '如果是請求尋呼某一ID號碼,則檢索當前此ID用戶是否登錄(即CurUser數組中是否存在此用戶),然后發送信息,通知此用戶響應呼叫并顯示主叫用戶ID號碼。</p>
<p> For i = 1 To tcpIndex</p>
<p>  If RequID = CurUser(i).ClientID And CurUser(i).ClientConnected = True Then</p>
<p>   tcpServer(i).SendData (SearhID)</p>
<p>  End If</p>
<p> Next</p>
<p> Exit Sub</p>
<p> ErrHandle:</p>
<p>  If Err.Number = sckBadState Then  '連接不正確</p>
<p>    CurUser(i).ClientConnected = False</p>
<p>    CurUser(i).ClientIP = ""</p>
<p>    Unload tcpServer(i)</p>
<p>    Resume Next</p>
<p>  End If</p>
<p>End Sub</p>
<p></p>
<p>  本程序僅提供了用Visual Basic 編寫網絡尋呼的思路和主要部分的實現過程,至于主叫方和被叫方建立連接后的通信并未擴展,讀者若有興趣,可在這方面加入具體的實現代碼,就可以給本程序增加更多的功能,如實時聊天,語音對話等。如果在服務器程序檢索到被叫方時,分別通知兩者客戶端程序,使主叫方和被叫方直接利用IP地址進行連接,則兩者的連接速度將會有大幅度的提高。  </p>

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲人成精品久久久久| 日韩毛片在线免费观看| 欧美日韩免费观看一区三区| 欧美成人精品3d动漫h| 国内精品久久久久影院色| 91精品国产aⅴ一区二区| 精品国产sm最大网站| 日韩一区在线看| 日日骚欧美日韩| 成人晚上爱看视频| 欧美一区二区三区四区久久| 最新久久zyz资源站| 精品亚洲porn| 欧美精品高清视频| 国产精品精品国产色婷婷| 日韩av不卡一区二区| 91性感美女视频| 国产欧美一区二区精品婷婷| 日韩成人av影视| 色悠久久久久综合欧美99| 久久精品一区二区三区四区| 午夜不卡av在线| 日本大香伊一区二区三区| 国产情人综合久久777777| 精品一区二区三区在线视频| 精品视频在线视频| 亚洲一区二区在线观看视频| 91丨九色丨国产丨porny| 欧美高清在线一区二区| 国产一区二区三区在线观看免费视频 | 亚洲欧美色综合| 国产一区91精品张津瑜| 欧美成人性战久久| 日韩av成人高清| 7777精品伊人久久久大香线蕉最新版| 亚洲日本乱码在线观看| 99视频热这里只有精品免费| 欧美国产综合一区二区| 粉嫩欧美一区二区三区高清影视 | 成人午夜激情视频| 精品国产乱码久久久久久久| 狂野欧美性猛交blacked| 91精品免费观看| 蜜桃在线一区二区三区| 日韩一区和二区| 国内外精品视频| 久久久精品黄色| 成人性色生活片| 中文字幕在线观看不卡视频| 一本到高清视频免费精品| 国产精品美女久久久久久久久| 成人理论电影网| 一区二区三区欧美亚洲| 欧美日韩在线免费视频| 免费在线看成人av| 久久你懂得1024| 9久草视频在线视频精品| 亚洲一区二区三区四区在线观看 | 国产一区二区免费视频| 欧美国产日韩亚洲一区| 色婷婷综合久久久久中文一区二区| 亚洲欧美韩国综合色| 欧美日韩综合在线| 紧缚捆绑精品一区二区| 中文文精品字幕一区二区| 91亚洲午夜精品久久久久久| 天天av天天翘天天综合网色鬼国产| 91精品国产综合久久久久久久| 狠狠色丁香婷婷综合| 国产精品水嫩水嫩| 欧美日韩一级黄| 激情六月婷婷久久| 亚洲伦理在线精品| 日韩亚洲欧美一区| 91丨porny丨蝌蚪视频| 青青草97国产精品免费观看无弹窗版| 久久亚洲一区二区三区明星换脸 | 日韩精品一区第一页| 久久亚洲精精品中文字幕早川悠里 | 国产在线精品一区二区三区不卡 | 久久精品国产一区二区| 中文字幕一区二区三区在线观看| 欧美体内she精高潮| 国产福利精品导航| 亚洲第一电影网| 久久久国产综合精品女国产盗摄| 色综合久久中文综合久久97| 久久99久久久久久久久久久| 国产精品传媒入口麻豆| 日韩女优电影在线观看| 91在线观看污| 激情图片小说一区| 爽爽淫人综合网网站| 国产精品久久久久久久久免费相片| 91精品国产麻豆| 色老汉一区二区三区| 国产成人h网站| 麻豆精品一区二区三区| 一区二区三区久久久| 亚洲国产成人午夜在线一区| 日韩女优视频免费观看| 欧美日本乱大交xxxxx| 91网站在线播放| 成人免费av在线| 国产精品996| 久久黄色级2电影| 午夜精品久久久久久| 亚洲裸体在线观看| 中文字幕一区二区5566日韩| 久久精品视频在线看| 欧美一区二区精品久久911| 欧美亚洲国产bt| 蜜臂av日日欢夜夜爽一区| 亚洲五月六月丁香激情| 亚洲国产精品成人综合| 日韩精品一区二区三区三区免费 | 99精品在线观看视频| 国产69精品久久久久777| 国产自产v一区二区三区c| 日本视频一区二区| 日韩影院免费视频| 日本欧美大码aⅴ在线播放| 午夜免费久久看| 日韩影院免费视频| 男人的天堂亚洲一区| 免费的国产精品| 理论电影国产精品| 精品一区二区三区免费观看| 国内精品自线一区二区三区视频| 另类专区欧美蜜桃臀第一页| 美女视频一区二区三区| 成人午夜又粗又硬又大| 日欧美一区二区| 日韩高清在线电影| 奇米影视在线99精品| 久久99日本精品| 国产精品中文欧美| 不卡电影免费在线播放一区| 91福利区一区二区三区| 欧美日韩色一区| 精品国产髙清在线看国产毛片 | 亚洲一区二区视频| 午夜精品福利视频网站| 日本亚洲免费观看| 国产精品夜夜爽| 91免费版在线| 555夜色666亚洲国产免| 亚洲精品在线观看视频| 中文字幕永久在线不卡| 午夜精品久久一牛影视| 黄网站免费久久| 91无套直看片红桃| 欧美一级欧美一级在线播放| 久久久久成人黄色影片| 亚洲欧洲日产国码二区| 首页欧美精品中文字幕| 国内精品免费**视频| 青青草国产精品亚洲专区无| 免费高清在线一区| 丁香婷婷综合五月| 精品视频一区三区九区| 欧美国产一区在线| 亚洲高清中文字幕| 国产精品一级二级三级| 欧美视频中文一区二区三区在线观看| 91精品国产综合久久香蕉的特点| 欧美激情综合在线| 日韩综合一区二区| 91玉足脚交白嫩脚丫在线播放| 日韩欧美一二三区| 一区二区三区在线观看动漫| 国产一区二区三区免费| 精品视频在线看| 国产精品日日摸夜夜摸av| 麻豆国产欧美日韩综合精品二区| 99久久精品免费看| 精品国产百合女同互慰| 亚洲福中文字幕伊人影院| 国产不卡在线视频| 欧美一级欧美三级在线观看| 一区二区免费在线播放| 国产高清亚洲一区| 欧美一二三四在线| 亚洲第一电影网| eeuss影院一区二区三区| 日韩一区二区三| 亚洲精品视频在线| 成人av在线播放网站| 亚洲精品一区二区精华| 日韩av电影天堂| 欧美日韩久久久| 亚洲综合在线五月| 97久久精品人人爽人人爽蜜臀| 国产三区在线成人av| 狠狠v欧美v日韩v亚洲ⅴ| 欧美成人三级在线| 麻豆精品在线播放| 日韩视频在线永久播放| 日韩电影在线观看网站| 91精品国产综合久久久久久久久久|