Using Async Socket Server : Socket Server « Socket Network « VB.Net Tutorial

Home
VB.Net Tutorial
1.Language Basics
2.Data Type
3.Operator
4.Statements
5.Date Time
6.Class Module
7.Development
8.Collections
9.Generics
10.Attributes
11.Event
12.LINQ
13.Stream File
14.GUI
15.GUI Applications
16.Windows Presentation Foundation
17.2D Graphics
18.I18N Internationlization
19.Reflection
20.Regular Expressions
21.Security
22.Socket Network
23.Thread
24.Windows
25.XML
26.Database ADO.net
27.Design Patterns
VB.Net
VB.Net by API
VB.Net Tutorial » Socket Network » Socket Server 
22.10.4.Using Async Socket Server
Using Async Socket Server
Imports System.Net.Sockets
Imports System.Net
Imports System.Threading
Imports System.Text
Imports System.Windows.Forms

public class UsingAsyncSocketServer
   public Shared Sub Main
        Application.Run(New Form1)
   End Sub
End class

Public Class Form1
    Inherits System.Windows.Forms.Form

    Public Sub New()
        MyBase.New()

        InitializeComponent()
    End Sub

    Protected Overloads Overrides Sub Dispose(ByVal disposing As Boolean)
        If disposing Then
            If Not (components Is NothingThen
                components.Dispose()
            End If
        End If
        MyBase.Dispose(disposing)
    End Sub

    Private components As System.ComponentModel.IContainer

    Friend WithEvents btnListener As System.Windows.Forms.Button
    Friend WithEvents lblConnection As System.Windows.Forms.Label
    Friend WithEvents lblPort As System.Windows.Forms.Label
    Friend WithEvents txtPort As System.Windows.Forms.TextBox
    Friend WithEvents btnClose As System.Windows.Forms.Button
    Friend WithEvents btnReceive As System.Windows.Forms.Button
    Friend WithEvents txtMessage As System.Windows.Forms.TextBox
    Friend WithEvents Label1 As System.Windows.Forms.Label
    Friend WithEvents btnSend As System.Windows.Forms.Button
    Friend WithEvents txtAccept As System.Windows.Forms.TextBox
    <System.Diagnostics.DebuggerStepThrough()Private Sub InitializeComponent()
        Me.btnListener = New System.Windows.Forms.Button()
        Me.lblConnection = New System.Windows.Forms.Label()
        Me.lblPort = New System.Windows.Forms.Label()
        Me.txtPort = New System.Windows.Forms.TextBox()
        Me.btnClose = New System.Windows.Forms.Button()
        Me.btnReceive = New System.Windows.Forms.Button()
        Me.txtMessage = New System.Windows.Forms.TextBox()
        Me.txtAccept = New System.Windows.Forms.TextBox()
        Me.Label1 = New System.Windows.Forms.Label()
        Me.btnSend = New System.Windows.Forms.Button()
        Me.SuspendLayout()
        '
        'btnListener
        '
        Me.btnListener.Font = New System.Drawing.Font("Microsoft Sans Serif"12.0!, System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, CType(136, Byte))
        Me.btnListener.Location = New System.Drawing.Point(33824)
        Me.btnListener.Name = "btnListener"
        Me.btnListener.Size = New System.Drawing.Size(11332)
        Me.btnListener.TabIndex = 0
        Me.btnListener.Text = "Start"
        '
        'lblConnection
        '
        Me.lblConnection.Font = New System.Drawing.Font("Microsoft Sans Serif"12.0!, System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, CType(136, Byte))
        Me.lblConnection.Location = New System.Drawing.Point(4172)
        Me.lblConnection.Name = "lblConnection"
        Me.lblConnection.Size = New System.Drawing.Size(9224)
        Me.lblConnection.TabIndex = 2
        Me.lblConnection.Text = "Info"
        '
        'lblPort
        '
        Me.lblPort.Font = New System.Drawing.Font("Microsoft Sans Serif"12.0!, System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, CType(136, Byte))
        Me.lblPort.Location = New System.Drawing.Point(2032)
        Me.lblPort.Name = "lblPort"
        Me.lblPort.Size = New System.Drawing.Size(11324)
        Me.lblPort.TabIndex = 3
        Me.lblPort.Text = "Port"
        '
        'txtPort
        '
        Me.txtPort.Font = New System.Drawing.Font("Microsoft Sans Serif"12.0!, System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, CType(136, Byte))
        Me.txtPort.Location = New System.Drawing.Point(14324)
        Me.txtPort.Name = "txtPort"
        Me.txtPort.Size = New System.Drawing.Size(13326)
        Me.txtPort.TabIndex = 4
        Me.txtPort.Text = "36000"
        '
        'btnClose
        '
        Me.btnClose.Font = New System.Drawing.Font("Microsoft Sans Serif"12.0!, System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, CType(136, Byte))
        Me.btnClose.Location = New System.Drawing.Point(46124)
        Me.btnClose.Name = "btnClose"
        Me.btnClose.Size = New System.Drawing.Size(10232)
        Me.btnClose.TabIndex = 5
        Me.btnClose.Text = "Stop"
        '
        'btnReceive
        '
        Me.btnReceive.Font = New System.Drawing.Font("Microsoft Sans Serif"12.0!, System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, CType(136, Byte))
        Me.btnReceive.Location = New System.Drawing.Point(276248)
        Me.btnReceive.Name = "btnReceive"
        Me.btnReceive.Size = New System.Drawing.Size(17532)
        Me.btnReceive.TabIndex = 6
        Me.btnReceive.Text = "Receive"
        '
        'txtMessage
        '
        Me.txtMessage.Location = New System.Drawing.Point(14372)
        Me.txtMessage.Multiline = True
        Me.txtMessage.Name = "txtMessage"
        Me.txtMessage.ScrollBars = System.Windows.Forms.ScrollBars.Vertical
        Me.txtMessage.Size = New System.Drawing.Size(43088)
        Me.txtMessage.TabIndex = 7
        Me.txtMessage.Text = ""
        '
        'txtAccept
        '
        Me.txtAccept.Location = New System.Drawing.Point(143168)
        Me.txtAccept.Multiline = True
        Me.txtAccept.Name = "txtAccept"
        Me.txtAccept.ScrollBars = System.Windows.Forms.ScrollBars.Vertical
        Me.txtAccept.Size = New System.Drawing.Size(43064)
        Me.txtAccept.TabIndex = 9
        Me.txtAccept.Text = ""
        '
        'Label1
        '
        Me.Label1.Font = New System.Drawing.Font("Microsoft Sans Serif"12.0!, System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, CType(136, Byte))
        Me.Label1.Location = New System.Drawing.Point(10168)
        Me.Label1.Name = "Label1"
        Me.Label1.Size = New System.Drawing.Size(14424)
        Me.Label1.TabIndex = 8
        Me.Label1.Text = "Data"
        '
        'btnSend
        '
        Me.btnSend.Font = New System.Drawing.Font("Microsoft Sans Serif"12.0!, System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, CType(136, Byte))
        Me.btnSend.Location = New System.Drawing.Point(461248)
        Me.btnSend.Name = "btnSend"
        Me.btnSend.Size = New System.Drawing.Size(11232)
        Me.btnSend.TabIndex = 10
        Me.btnSend.Text = "Data sent back"
        '
        'Form1
        '
        Me.AutoScaleBaseSize = New System.Drawing.Size(614)
        Me.ClientSize = New System.Drawing.Size(665309)
        Me.Controls.AddRange(New System.Windows.Forms.Control() {Me.btnSend, Me.txtAccept, Me.Label1, Me.txtMessage, Me.btnReceive, Me.btnClose, Me.txtPort, Me.lblPort, Me.lblConnection, Me.btnListener})
        Me.Name = "Form1"
        Me.Text = "Form1"
        Me.ResumeLayout(False)

    End Sub

    Dim strMessage
    Dim myListener As Socket
    Dim bteAccept(65536As Byte
    Dim bteSend(65536As Byte
    Dim EndSocket As Socket

    Private Sub btnListener_Click(ByVal sender As System.Object, ByVal e As System.EventArgsHandles btnListener.Click
        Dim myThread As New Thread(New ThreadStart(AddressOf StartListen))
        myThread.Start()
    End Sub

    Private Sub btnReceive_Click(ByVal sender As System.Object, ByVal e As System.EventArgsHandles btnReceive.Click
        Dim myThread As New Thread(New ThreadStart(AddressOf ReceiveStart))
        myThread.Start()
    End Sub

    Private Sub btnSend_Click(ByVal sender As System.Object, ByVal e As System.EventArgsHandles btnSend.Click
        Dim myThread As New Thread(New ThreadStart(AddressOf SendStart))
        myThread.Start()
    End Sub


    Private Sub StartListen()
        Dim intPort As Integer
        Dim bidEndPoint As IPEndPoint

        intPort = Integer.Parse(txtPort.Text)
        bidEndPoint = New IPEndPoint(IPAddress.Parse("10.2.3.127"), intPort)
        myListener = New Socket _
                     (AddressFamily.InterNetwork, _
                     SocketType.Stream, _
                     ProtocolType.Tcp)
        Try
            '  myListener.Bind(bidEndPoint)
            Dim myAsyncCallBack As New AsyncCallback(AddressOf AcceptEnd)
            myListener.Listen(intPort)
            myListener.BeginAccept(myAsyncCallBack, myListener)
            txtMessage.Text += vbCrLf + "Waiting"

            strMessage += "//Head..." + vbCrLf
            strMessage += "//Server Send Message ..." + vbCrLf
            strMessage += "--------------------------------" + vbCrLf


        Catch ex As SocketException
            Console.WriteLine(ex.Message)

        End Try
    End Sub

    Private Sub AcceptEnd(ByVal pIAsyncResult As IAsyncResult)
        EndSocket = myListener.EndAccept(pIAsyncResult)
    End Sub

    Private Sub ReceiveStart()
        Dim myAsyncCallBack As New AsyncCallback(AddressOf ReceiveData)

        EndSocket.BeginReceive _
          (bteAccept, 0655360, _
          myAsyncCallBack, EndSocket)

    End Sub

    Private Sub ReceiveData(ByVal pIAsyncResult As IAsyncResult)
        Dim intByte As Integer
        intByte = EndSocket.EndReceive(pIAsyncResult)
        If intByte > Then
            strMessage += Encoding.ASCII.GetString(bteAccept)
            txtAccept.Text = strMessage
        End If
    End Sub

    Private Sub SendStart()
        Dim myAsyncCallBack As New AsyncCallback(AddressOf SendData)
        bteSend = Encoding.ASCII.GetBytes(strMessage)

        EndSocket.BeginSend _
          (bteSend, 0, bteSend.Length, _
          SocketFlags.DontRoute, myAsyncCallBack, EndSocket)
    End Sub

    Private Sub SendData(ByVal pIAsyncResult As IAsyncResult)
        Dim intSend As Integer
        intSend = EndSocket.EndSend(pIAsyncResult)
        txtMessage.Text += vbCrLf + "Data sent " + intSend.ToString + "bytes"
    End Sub

    Private Sub btnClose_Click(ByVal sender As System.Object, ByVal e As System.EventArgsHandles btnClose.Click
        myListener.Close()
    End Sub


    Private Sub Form1_Load(ByVal sender As System.Object, ByVal e As System.EventArgsHandles MyBase.Load

    End Sub
End Class
22.10.Socket Server
22.10.1.Socket server
22.10.2.Date time server based on System.Net.Sockets.Socket
22.10.3.Socket Server with user interfaceSocket Server with user interface
22.10.4.Using Async Socket ServerUsing Async Socket Server
www.java2java.com | Contact Us
Copyright 2009 - 12 Demo Source and Support. All rights reserved.
All other trademarks are property of their respective owners.