35.1 Komponenta WinSock Úvod
35.2 Tvorba programu pro příjem dat (Server)
35.3 Program pro odesílání zpráv (klient)
35.4 Tvorba aplikace pro dvoustranou komunikaci
35.5 Další použití
35.6 Domácí úkol
35.7 V Další Lekci
35.1 Komponenta WinSock Úvod
Nejdříve si povíme, k čemu tato komponenta slouží, a pak se podíváme na to, jak ji využít. A pak si nastíníme něco o komponentě, jak vytvořit takové malé vlastní, dejme tomu, ICQ.
Komponenta WinSock umožňuje jednoduchou síťovou komunikaci. Můžeme si tedy posílat krátké zprávy nebo příkazy na vzdálený PC.
Ještě, než se pustíme do tvorby složitých programů, řekneme si nějaké základní věci. My budeme komunikovat přes IP adresu. To znamená, že ji budeme muset znát. A budeme komunikovat přes určitý port. Pokud spolu budou chtít dva počítače komunikovat, budou muset mít stejný zapnutý port. Více si o tom všem povíme na praktických příkladech.
Komponentu musíme nejdříve přidat: Komponenty >> Microsoft WinSock Control
35.2 Tvorba programu pro příjem dat (Server)
Následující kód tvoří základ, bez kterého se neobejdeme.
Private Sub Form_Load()
Winsock1.RemotePort = 326 'nastavíme číslo portu
Winsock1.Listen 'nastavíme poslech na tomto portu
End Sub
Private Sub Winsock1_ConnectionRequest(ByVal requestID As Long)
Winsock1.Close ' uzavře ostatní komunikaci
Winsock1.Accept requestID 'akceptuje příchozí požadavek na připojení
End Sub
Private Sub Winsock1_DataArrival(ByVal bytesTotal As Long)
Winsock1.GetData (nazev_promene) 'do teto proměnné se data uloži
End Sub
V události Form Load nastavíme port. A taky komponentu na to, aby sledovala to, co se děje na portu 326. Pokud se na portu objeví požadavek na přijmutí spojení, nastane událost komponenty Winsock ConnectionRequest. Ta uzavře ostatní spojení a toto spojení akceptuje. Pokud jsme již úspěšně spojeni a přijdou přes komponentu nějaká data, nastane událost DataArrival a v ní se došlá data uloží do proměnné. Jak s nimi naložíte, je jen na vás.
35.3 Program pro odesílání zpráv (klient)
Klient je druhá část, kterou musíme naprogramovat, abychom to mohli využít.
Private Sub cmdConnect_Click()
Winsock1.RemoteHost = ip_adresa 'zde zadáme IP adresu ke které se chcem připojit
Winsock1.RemotePort = 326 'zde číslo portu na kterém chceme komunikovat
Winsock1.Connect 'tímto vyšleme požadavek na připojení
Do Until Winsock1.State = sckConnected
DoEvents
If Winsock1.State = sckError Then GoTo error
Loop
Exit Sub
error:
MsgBox "spojení se nezdařilo"
End Sub
Private Sub cmdSend_Click()
If Winsock1.State = sckConnected Then
Winsock1.SendData (Data)
Else
MsgBox "nejse připojen"
End If
End Sub
Nejprve komponentě předáme číslo portu a IP adresu, ať ví, jak a s kým komunikovat. Potom jí řekneme, ať se připojí a vyčkáváme v cyklu, dokud se nepřipojí. V cyklu také kontoluje, zda nedošlo k chybě, pokud ano, program nás o tom informuje a ukončí pokus o připojení. Další část kódu tvoří procedura, která odesílá data, ta první zkontroluje, zda- li jste připojen a pokud ano, odešle data na server. Je vhodné připojení vždy uzavírat příkazem:
Winsock1.Close
Musím vás také upozornit, že špatně zadaná IP adresa může způsobit pád celého Visual Studia. A další chybou může být to, že si nějakým způsobem zablokujete komunikační port. Pak nezbývá nic jiného, než ho změnit. Časem se to zase srovná.
Tuto aplikaci můžete otestovat při použití této IP 127.0.0.1
35.4 Tvorba aplikace pro dvoustranou komunikaci.
Tato aplikace má proti předchozím dvěma jednu nevýhodu, nelze ji testovat na jednom PC. Ale zbytek jsou jenom výhody :). Rovnou už se podíváme na kód:
Private Sub Form_Load()
Winsock1.LocalPort = 1000 'Nastavení portu
Winsock1.Listen 'nastavení aplikace ne poslech na portu
End Sub
Private Sub cmdConnect_Click()
If Winsock1.State <> sckConnected Then 'Zkusíme zda nejsme připojení pokud ne tak se připojíme
If Winsock1.State <> sckClose Then Winsock1.Close 'Uzavřeme spojení pokud není uzavřeno
Winsock1.RemotePort = 1000 'Natevní portu
Winsock1.RemoteHost = strIP 'Nastavení IP
Winsock1.Connect 'Příkaz k připojení
Do While Winsock1.State <> sckConnected 'testuje zdali spojení proběhlo úspěšně
DoEvents 'příkaz k čekání
If Winsock1.State = sckError Then 'Vyvolá výstrahu pokud se nepovede spojení
' nějaký způsob výstrahy, že se nepovedlo připojit
Exit Sub
End If
Loop
End If
End Sub
Private Sub cmdSendData_Click()
If Winsock1.State = sckConnected Then
Winsock1.SendData (text_zprávy)
Else
'upozornění o tom, že nejste připojeni
End If
End Sub
Private Sub Winsock1_ConnectionRequest(ByVal requestID As Long)
If Winsock1.State <> sckClosed Then Winsock1.Close 'uzavření winsock
Winsock1.Accept requestID 'Akceptování připojení
End Sub
Private Sub Winsock1_DataArrival(ByVal bytesTotal As Long)
Dim Prichozi_Data As String
Winsock1.GetData Prichozi_Data
'zpracování příchozích dat. Například zobrazením messageboxu nebo v okně chatu
End Sub
Kód je, řekl bych, dostatečně okomentován, tak není třeba psát něco dalšího.
35.5 Další použití
Pomocí této komponenty můžete dělat více, než jen posílat zprávy, můžete posílat i soubory, a to tím způsobem, že je rozložíte na malé řetězce a potom je zase složíte. Mužete pomocí ní posílat i příkazy například pro správce učeben. Kdy jdou na počítačích ostatních programy pro příjem a na hlavním počítači je vysílač, kterým můžeme všechny PC vypnout.
Pomocí této komponenty můžete zjistit i vlastní IP a název PC. A to tímto příkazem:
Print Winsock1.LocalIP
Print Winsock1.LocalHostName
35.6 Domácí úkol
Cokoliv co používá komponentu Winsock.
35.7 V Další Lekci
Asi tvorba vlastních binárních souborů.