232 lines
6 KiB
Text
232 lines
6 KiB
Text
|
' Gambas class file
|
||
|
|
||
|
'********************************************
|
||
|
' THIS EXAMPLE SHOWS HOW TO USE THE 'Socket'
|
||
|
' CLASS FROM 'gb.net' COMPONENT
|
||
|
'
|
||
|
' (C) 2003-2004 Daniel Campos Fernández
|
||
|
' (danielcampos@netcourrier.com)
|
||
|
'********************************************
|
||
|
Private CurProtocol As Integer
|
||
|
|
||
|
Public Sub Form_Open()
|
||
|
|
||
|
CurProtocol = 0
|
||
|
|
||
|
End
|
||
|
|
||
|
Public Sub MySocket_Ready()
|
||
|
'***********************************
|
||
|
' When connection proccess has finished
|
||
|
' successfully, "Connected" event will raise
|
||
|
'***********************************
|
||
|
|
||
|
timTimeout.Enabled = False
|
||
|
If CurProtocol = 1 Then
|
||
|
lblMessage.Text = ("Connected to path ") & MySocket.Path
|
||
|
Else
|
||
|
lblMessage.Text = ("Connected to remote host ") & MySocket.Path
|
||
|
lblMessage.Text = lblMessage.Text & (" - Using local address : ") & MySocket.LocalHost & ":" & MySocket.LocalPort
|
||
|
End If
|
||
|
Me.Enabled = True
|
||
|
Set_Interface(True)
|
||
|
|
||
|
End
|
||
|
|
||
|
Public Sub MySocket_Closed()
|
||
|
'********************************************
|
||
|
' this event will raise when foreing host
|
||
|
' closes the socket by any reason
|
||
|
'********************************************
|
||
|
|
||
|
lblMessage.Caption = ("Connection Closed by foreign host.")
|
||
|
Me.Enabled = True
|
||
|
Set_Interface(False)
|
||
|
|
||
|
End
|
||
|
|
||
|
Public Sub MySocket_Found()
|
||
|
'********************************************
|
||
|
' this event will raise when foreing host
|
||
|
' name has been translated to IP
|
||
|
'********************************************
|
||
|
|
||
|
lblMessage.Caption = ("Host Found. Connecting...")
|
||
|
|
||
|
End
|
||
|
|
||
|
Public Sub MySocket_Read()
|
||
|
'****************************************
|
||
|
' When some data arrives from the remote
|
||
|
' part of the socket, "DataAvailable" event
|
||
|
' is raised
|
||
|
'****************************************
|
||
|
|
||
|
Dim S As String
|
||
|
|
||
|
If MySocket.Status = Net.Connected Then
|
||
|
Read #MySocket, S, Lof(MySocket)
|
||
|
txtReceive.Pos = txtReceive.Length
|
||
|
txtReceive.Insert(S)
|
||
|
End If
|
||
|
|
||
|
End
|
||
|
|
||
|
Public Sub MySocket_Error()
|
||
|
'**********************************
|
||
|
' this is the function to
|
||
|
' handle Errors when trying
|
||
|
' to read or write to the socket
|
||
|
'**********************************
|
||
|
|
||
|
Select Case MySocket.Status
|
||
|
Case Net.CannotCreateSocket
|
||
|
lblMessage.Text = ("The system does not allow to create a socket")
|
||
|
Case Net.HostNotFound
|
||
|
lblMessage.Text = ("Host not Found")
|
||
|
Case Net.ConnectionRefused
|
||
|
lblMessage.Text = ("Unable to Connect. Connection Refused")
|
||
|
Case Net.CannotRead
|
||
|
lblMessage.Text = ("Error Reading Data")
|
||
|
Case Net.CannotWrite
|
||
|
lblMessage.Text = ("Error Writing Data")
|
||
|
End Select
|
||
|
Set_Interface(False)
|
||
|
|
||
|
End
|
||
|
|
||
|
Private Sub Set_Interface(bState As Boolean)
|
||
|
'****************************************
|
||
|
' An auxiliar method to enable/disable
|
||
|
' controls in the formulary , when
|
||
|
' connection is stablished or closed
|
||
|
'****************************************
|
||
|
|
||
|
btnConnect.Enabled = Not bState
|
||
|
txtHost.Enabled = Not bState
|
||
|
txtPort.Enabled = Not bState
|
||
|
cmbProtocol.Enabled = Not bState
|
||
|
Label5.Enabled = Not bState
|
||
|
btnClose.Enabled = bState
|
||
|
timTimeout.Enabled = bState
|
||
|
'TextArea1.Enabled=bState
|
||
|
btnSend.Enabled = bState
|
||
|
txtSend.Enabled = bState
|
||
|
|
||
|
If bState Then
|
||
|
txtReceive.Text = ""
|
||
|
txtReceive.SetFocus
|
||
|
Endif
|
||
|
|
||
|
End
|
||
|
|
||
|
Public Sub btnConnect_Click()
|
||
|
|
||
|
'******************************************
|
||
|
' To connect to remote host we call to
|
||
|
' connectsocket method, passing Host Name
|
||
|
' and port as arguments
|
||
|
'******************************************
|
||
|
Dim RetVal As Integer
|
||
|
|
||
|
btnConnect.Enabled = False
|
||
|
Select Case CurProtocol
|
||
|
Case 0
|
||
|
' Stablishing a TCP connection.
|
||
|
' Here we use Host and
|
||
|
' Port properties, we could also
|
||
|
' do directly MySock.Connect(TextBox1.Text,VAL(TextBox2.Text))
|
||
|
MySocket.Host = txtHost.Text
|
||
|
MySocket.Port = Val(txtPort.Text)
|
||
|
MySocket.Connect()
|
||
|
Case 1
|
||
|
' Stablishing a Local connection.
|
||
|
' Here we use Path and
|
||
|
' Port properties, we could also
|
||
|
' do directly MySock.Connect(TextBox1.Text,0)
|
||
|
MySocket.Path = txtHost.Text
|
||
|
MySocket.Port = Net.Local
|
||
|
MySocket.Connect()
|
||
|
End Select
|
||
|
If MySocket.Status > Net.Inactive Then
|
||
|
If CurProtocol = 0 Then
|
||
|
'**************************
|
||
|
' TCP : connection in progress...
|
||
|
'**************************
|
||
|
btnClose.Enabled = True
|
||
|
'ME.Enabled=FALSE
|
||
|
lblMessage.Text = ("Looking up host name...")
|
||
|
timTimeout.Delay = 10000 ' we'll wait a maximun time of 10 seconds
|
||
|
timTimeout.Enabled = True
|
||
|
End If
|
||
|
End If
|
||
|
|
||
|
End
|
||
|
|
||
|
Public Sub timTimeout_Timer()
|
||
|
|
||
|
'***************************
|
||
|
' timeout trying to connect
|
||
|
'***************************
|
||
|
Me.Enabled = True
|
||
|
timTimeout.Enabled = False
|
||
|
If MySocket.Status <> Net.Connected Then
|
||
|
Close MySocket
|
||
|
Set_Interface(False)
|
||
|
lblMessage.Text = ("Timeout trying to stablish connection")
|
||
|
End If
|
||
|
|
||
|
End
|
||
|
|
||
|
Public Sub btnClose_Click()
|
||
|
|
||
|
'**********************************
|
||
|
' Here we close the connection
|
||
|
' to remote host
|
||
|
'**********************************
|
||
|
Close MySocket
|
||
|
Set_Interface(False)
|
||
|
lblMessage.Text = ("Connection closed by user")
|
||
|
|
||
|
End
|
||
|
|
||
|
Public Sub btnSend_Click()
|
||
|
'****************************************************
|
||
|
' Here we send data to the remote part of the socket.
|
||
|
' We have to be sure that connection is active
|
||
|
'****************************************************
|
||
|
|
||
|
If MySocket.Status = Net.Connected Then
|
||
|
Write #MySocket, txtSend.Text, Len(txtSend.Text)
|
||
|
txtSend.Text = ""
|
||
|
End If
|
||
|
|
||
|
End
|
||
|
|
||
|
Public Sub Form_Close()
|
||
|
|
||
|
'*********************
|
||
|
' Close possible Stablished connections
|
||
|
'*********************
|
||
|
If MySocket.Status > 0 Then Close #MySocket
|
||
|
|
||
|
End
|
||
|
|
||
|
Public Sub cmbProtocol_Click()
|
||
|
'**************************************************
|
||
|
' Here we select protocol to use : TCP,UDP or UNIX
|
||
|
'**************************************************
|
||
|
|
||
|
CurProtocol = cmbProtocol.Index
|
||
|
If CurProtocol = 0 Then
|
||
|
Label2.Visible = True
|
||
|
txtPort.Visible = True
|
||
|
Label1.Text = "Host :"
|
||
|
Else
|
||
|
Label2.Visible = False
|
||
|
txtPort.Visible = False
|
||
|
Label1.Text = "Path :"
|
||
|
End If
|
||
|
|
||
|
End
|