程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> Visual Basic語言 >> VB綜合教程 >> 用VB編寫網絡尋呼機

用VB編寫網絡尋呼機

編輯:VB綜合教程
提起ICQ的大名,愛好電腦的朋友一定不會感到陌生的吧?ICQ就是互聯網上的尋呼機,無論什麼時候,只要你的朋友在線,你只需在ICQ中輸入他的ID號碼,你就可以在互聯網上呼到他。ICQ由於其方便、快捷,且擁有眾多的注冊用戶而一舉成為互聯網上最流行的網絡尋呼機,它幾乎成為每一個上網用戶的必備之物。當你在使用ICQ的時候,是否會想過自己動手編寫一個網絡尋呼機呢?這其實在VB中就可以實現。
  ----網絡尋呼的原理就是當客戶端程序連接服務器時,通過服務器搜索所要呼叫的ID號碼,如果檢測到此用戶且該用戶正處於聯網狀態,則服務器通知此用戶的客戶端程序響應主叫方客戶端程序,然後在主叫方和被叫方建立連接後,雙方就可以聊天或進行其它的通信。
  
  ----在VB中編寫網絡尋呼機需要建立兩個程序,一個為客戶端程序Client,一個為服務器端程序Server。
  
  ----一、在Client工程中建立一個窗體,加載WinSock控件,稱為tcpClient,協議選擇TCP。再加入四個文本框,用以輸入服務器的IP地址、服務器端口號,被呼叫的網絡尋呼ID號以及用戶登錄ID號。然後再在窗體中加入三個按鈕,分別命名為“連接”、“斷開”和“退出”,點擊“連接”按鈕,並進行如下初始化連接,代碼如下:
  
  PrivateSubCommand1_Click()
  IfLen(Text1.Text)=0AndLen(Text2.Text)=0Then
  MsgBox("請輸入主機名或主機IP地址。")
  ExitSub
  ElseIfLen(Text1.Text)>0Then
  tcpClient.RemoteHost=Text1.Text
  tcpClient.RemotePort=Text2.Text
  EndIf
  tcpClient.Connect
  Timer1.Enabled=True
  EndSub
  
  PrivateSubCommand2_Click()
  tcpClient.Close   '斷開連接
  EndSub
  
  PrivateSubCommand3_Click()
  End
  EndSub
  
  PrivateSubForm_Load()
  Text2.Text="1001"
  EndSub
  
  PrivateSubtcpClient_Connect()
  tcpClient.SendData(Text3.Text&"@"&Text4.Text)
  EndSub
  
  PrivateSubtcpClient_DataArrival(ByVal
  bytesTotalAsLong)
  DimstrDataAsString
  tcpClient.GetDatastrData
  strData=strData "呼叫" 
  '在收到呼叫消息後彈出一對話框並顯示主叫方ID號碼
  MsgBox(strData)
  EndSub
  
  ----二、在服務器端Server工程中也建立一個窗體,加載WinSock控件,稱為tcpServer,協議選擇TCP,設置其Index值為0,並在工程中添加模塊。
  ----內容如下:
  
  PrivateTypeActiveUser
  ClientIPAsString'記錄客戶的IP地址
  ClientPortAsInteger'記錄當前會話的端口
  ClientIDAsLong'記錄客戶的ID號碼
  ClientConnectedAsBoolean
  '客戶連接狀態,True表示已連接,False表示沒有連接
  EndType
  DimCurUser()AsActiveUser
  DimtcpIndexAsInteger'跟蹤當前建立連接數
  
  在Form_Load事件中加入如下代碼:
  PrivateSubForm_Load()
  tcpServer(0).Protocol=sckTCPProtocol
  tcpServer(0).LocalPort=1001
  '將LocalPort屬性設置為一個整數。
  tcpServer(0).Listen'然後調用Listen方法。
  tcpIndex=1
  EndSub
  
  ----准備應答客戶端程序的請求連接,使用ConnectionRequest事件來應答戶端程序的請求,代碼如下:
  PrivateSubtcpServer_ConnectionRequest
  (IndexAsInteger,ByValrequestIDAsLong)
  DimiAsInteger
  OnErrorGoToErrHandle
  Fori=1TotcpIndex'選擇一個空閒端口
  IfCurUser(i).ClientConnected=
  FalseAndi<>tcpIndexThen
  LoadtcpServer(i)
  tcpServer(i).LocalPort=CurUser(i).ClientPort-1
  tcpServer(i).AcceptrequestID
  ExitFor
  ElseIfCurUser(i).ClientConnected=FalseThen
  LoadtcpServer(i)
  tcpServer(i).LocalPort=Port
  IftcpServer(i).State<>sckClosedThen
  tcpServer(i).Close
  EndIf
  tcpServer(i).AcceptrequestID
  ExitFor
  EndIf
  Next
  DoEvents
  '測試連接是否成功
  IftcpServer(i).State=sckConnectedThen
  Ifi=tcpIndexThen
  '已經沒有可用端口,記錄客戶的IP地址和端口號
  tcpIndex=tcpIndex 1
  Port=Port 1
  ReDimPreserveCurUser(tcpIndex)
  CurUser(i).ClientIP=tcpServer(i).RemoteHostIP
  CurUser(i).ClientConnected=True
  CurUser(i).ClientPort=Port
  CurUser(tcpIndex).ClientConnected=False
  Else
  CurUser(i).ClientIP=tcpServer(i).RemoteHostIP
  CurUser(i).ClientPort=Port
  CurUser(i).ClientConnected=True
  EndIf
  EndIf
  ExitSub
  ErrHandle:
  ResumeNext
  '檢查控件的State屬性,如未關閉,在接受新的連接之前關閉此連接。
  IftcpServer(0).State<>sckClosedThen
  tcpServer(0).Close
  tcpServer(0).AcceptrequestID
  '接受具有requestID參數的,連接。
  EndSub
  
  PrivateSubtcpServer_DataArrival(IndexAsInteger,
  ByValbytesTotalAsLong)
  DimiAsInteger
  DimsAsString
  DimRequIDAsLong'主叫方ID號碼
  DimSearchIDAsLong'被叫方ID號碼
  
  OnErrorGoToErrHandle
  tcpServer(Index).GetDatas,vbString
  '接收數據並存入s 
  IfMid(s,i,1)="@"Then
  '分離s中的主叫方和被叫方ID號碼
  SearhID=Left(s,i-1)'把號存入mKey
  RequID=Right(s,Len(s)-i)'ID存入RequID
  EndIf
  
  ----'如果是請求尋呼某一ID號碼,則檢索當前此ID用戶是否登錄(即CurUser數組中是否存在此用戶),然後發送信息,通知此用戶響應呼叫並顯示主叫用戶ID號碼。
  Fori=1TotcpIndex
  IfRequID=CurUser(i).ClientIDAndCurUser(i)
  .ClientConnected=TrueThen
  tcpServer(i).SendData(SearhID)
  EndIf
  Next
  ExitSub
  ErrHandle:
  IfErr.Number=sckBadStateThen'連接不正確
  CurUser(i).ClientConnected=False
  CurUser(i).ClientIP=""
  UnloadtcpServer(i)
  ResumeNext
  EndIf
  EndSub
  
  ----本程序僅提供了用VisualBasic編寫網絡尋呼的思路和主要部分的實現過程,至於主叫方和被叫方建立連接後的通信並未擴展,讀者若有興趣,可在這方面加入具體的實現代碼,就可以給本程序增加更多的功能,如實時聊天,語音對話等。如果在服務器程序檢索到被叫方時,分別通知兩者客戶端程序,使主叫方和被叫方直接利用IP地址進行連接,則兩者的連接速度將會有大幅度的提高。->

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved