TcpClient Class 
Definition
Important
Some information relates to prerelease product that may be substantially modified before it’s released. Microsoft makes no warranties, express or implied, with respect to the information provided here.
Provides client connections for TCP network services.
public ref class TcpClient : IDisposablepublic class TcpClient : IDisposabletype TcpClient = class
    interface IDisposablePublic Class TcpClient
Implements IDisposable- Inheritance
- 
				TcpClient
- Implements
Examples
The following code example establishes a TcpClient connection.
static void Connect(String server, String message)
{
  try
  {
    // Create a TcpClient.
    // Note, for this client to work you need to have a TcpServer
    // connected to the same address as specified by the server, port
    // combination.
    Int32 port = 13000;
    // Prefer a using declaration to ensure the instance is Disposed later.
    using TcpClient client = new TcpClient(server, port);
    // Translate the passed message into ASCII and store it as a Byte array.
    Byte[] data = System.Text.Encoding.ASCII.GetBytes(message);
    // Get a client stream for reading and writing.
    NetworkStream stream = client.GetStream();
    // Send the message to the connected TcpServer.
    stream.Write(data, 0, data.Length);
    Console.WriteLine("Sent: {0}", message);
    // Receive the server response.
    // Buffer to store the response bytes.
    data = new Byte[256];
    // String to store the response ASCII representation.
    String responseData = String.Empty;
    // Read the first batch of the TcpServer response bytes.
    Int32 bytes = stream.Read(data, 0, data.Length);
    responseData = System.Text.Encoding.ASCII.GetString(data, 0, bytes);
    Console.WriteLine("Received: {0}", responseData);
    // Explicit close is not necessary since TcpClient.Dispose() will be
    // called automatically.
    // stream.Close();
    // client.Close();
  }
  catch (ArgumentNullException e)
  {
    Console.WriteLine("ArgumentNullException: {0}", e);
  }
  catch (SocketException e)
  {
    Console.WriteLine("SocketException: {0}", e);
  }
  Console.WriteLine("\n Press Enter to continue...");
  Console.Read();
}
Shared Sub Connect(server As [String], message As [String])
   Try
      ' Create a TcpClient.
      ' Note, for this client to work you need to have a TcpServer 
      ' connected to the same address as specified by the server, port
      ' combination.
      Dim port As Int32 = 13000
      ' Prefer using declaration to ensure the instance is Disposed later.
      Using client As New TcpClient(server, port)
      
         ' Translate the passed message into ASCII and store it as a Byte array.
         Dim data As [Byte]() = System.Text.Encoding.ASCII.GetBytes(message)
         
         ' Get a client stream for reading and writing.
         Dim stream As NetworkStream = client.GetStream()
         
         ' Send the message to the connected TcpServer. 
         stream.Write(data, 0, data.Length)
         
         Console.WriteLine("Sent: {0}", message)
         
         ' Receive the server response.
         ' Buffer to store the response bytes.
         data = New [Byte](256) {}
         
         ' String to store the response ASCII representation.
         Dim responseData As [String] = [String].Empty
         
         ' Read the first batch of the TcpServer response bytes.
         Dim bytes As Int32 = stream.Read(data, 0, data.Length)
         responseData = System.Text.Encoding.ASCII.GetString(data, 0, bytes)
         Console.WriteLine("Received: {0}", responseData)
         
         ' Explicit close is not necessary since TcpClient.Dispose() will be
         ' called automatically.
         ' stream.Close()
         ' client.Close()
      End Using
   Catch e As ArgumentNullException
      Console.WriteLine("ArgumentNullException: {0}", e)
   Catch e As SocketException
      Console.WriteLine("SocketException: {0}", e)
   End Try
   
   Console.WriteLine(ControlChars.Cr + " Press Enter to continue...")
   Console.Read()
End Sub
Remarks
The TcpClient class provides simple methods for connecting, sending, and receiving stream data over a network in synchronous blocking mode.
In order for TcpClient to connect and exchange data, a TcpListener or Socket created with the TCP ProtocolType must be listening for incoming connection requests. You can connect to this listener in one of the following two ways:
- Create a - TcpClientand call one of the three available Connect methods.
- Create a - TcpClientusing the host name and port number of the remote host. This constructor will automatically attempt a connection.
Note
If you want to send connectionless datagrams in synchronous blocking mode, use the UdpClient class.
Notes to Inheritors
To send and receive data, use the GetStream() method to obtain a NetworkStream. Call the Write(Byte[], Int32, Int32) and Read(Byte[], Int32, Int32) methods of the NetworkStream to send and receive data with the remote host. Use the Close(Int32) method to release all resources associated with the TcpClient.
Constructors
| TcpClient() | Initializes a new instance of the TcpClient class. | 
| TcpClient(AddressFamily) | Initializes a new instance of the TcpClient class with the specified family. | 
| TcpClient(IPEndPoint) | Initializes a new instance of the TcpClient class and binds it to the specified local endpoint. | 
| TcpClient(String, Int32) | Initializes a new instance of the TcpClient class and connects to the specified port on the specified host. | 
Properties
| Active | Gets or sets a value that indicates whether a connection has been made. | 
| Available | Gets the amount of data that has been received from the network and is available to be read. | 
| Client | Gets or sets the underlying Socket. | 
| Connected | Gets a value indicating whether the underlying Socket for a TcpClient is connected to a remote host. | 
| ExclusiveAddressUse | Gets or sets a Boolean value that specifies whether the TcpClient allows only one client to use a port. | 
| LingerState | Gets or sets information about the linger state of the associated socket. | 
| NoDelay | Gets or sets a value that disables a delay when send or receive buffers are not full. | 
| ReceiveBufferSize | Gets or sets the size of the receive buffer. | 
| ReceiveTimeout | Gets or sets the amount of time a TcpClient will wait to receive data once a read operation is initiated. | 
| SendBufferSize | Gets or sets the size of the send buffer. | 
| SendTimeout | Gets or sets the amount of time a TcpClient will wait for a send operation to complete successfully. | 
Methods
| BeginConnect(IPAddress, Int32, AsyncCallback, Object) | Begins an asynchronous request for a remote host connection. The remote host is specified by an IPAddress and a port number (Int32). | 
| BeginConnect(IPAddress[], Int32, AsyncCallback, Object) | Begins an asynchronous request for a remote host connection. The remote host is specified by an IPAddress array and a port number (Int32). | 
| BeginConnect(String, Int32, AsyncCallback, Object) | Begins an asynchronous request for a remote host connection. The remote host is specified by a host name (String) and a port number (Int32). | 
| Close() | Disposes this TcpClient instance and requests that the underlying TCP connection be closed. | 
| Connect(IPAddress, Int32) | Connects the client to a remote TCP host using the specified IP address and port number. | 
| Connect(IPAddress[], Int32) | Connects the client to a remote TCP host using the specified IP addresses and port number. | 
| Connect(IPEndPoint) | Connects the client to a remote TCP host using the specified remote network endpoint. | 
| Connect(String, Int32) | Connects the client to the specified port on the specified host. | 
| ConnectAsync(IPAddress, Int32, CancellationToken) | Connects the client to a remote TCP host using the specified IP address and port number as an asynchronous operation. | 
| ConnectAsync(IPAddress, Int32) | Connects the client to a remote TCP host using the specified IP address and port number as an asynchronous operation. | 
| ConnectAsync(IPAddress[], Int32, CancellationToken) | Connects the client to a remote TCP host using the specified IP addresses and port number as an asynchronous operation. | 
| ConnectAsync(IPAddress[], Int32) | Connects the client to a remote TCP host using the specified IP addresses and port number as an asynchronous operation. | 
| ConnectAsync(IPEndPoint, CancellationToken) | Connects the client to a remote TCP host using the specified endpoint as an asynchronous operation. | 
| ConnectAsync(IPEndPoint) | Connects the client to a remote TCP host using the specified endpoint as an asynchronous operation. | 
| ConnectAsync(String, Int32, CancellationToken) | Connects the client to the specified TCP port on the specified host as an asynchronous operation. | 
| ConnectAsync(String, Int32) | Connects the client to the specified TCP port on the specified host as an asynchronous operation. | 
| Dispose() | Releases the managed and unmanaged resources used by the TcpClient. | 
| Dispose(Boolean) | Releases the unmanaged resources used by the TcpClient and optionally releases the managed resources. | 
| EndConnect(IAsyncResult) | Ends a pending asynchronous connection attempt. | 
| Equals(Object) | Determines whether the specified object is equal to the current object.(Inherited from Object) | 
| Finalize() | Frees resources used by the TcpClient class. | 
| GetHashCode() | Serves as the default hash function.(Inherited from Object) | 
| GetStream() | Returns the NetworkStream used to send and receive data. | 
| GetType() | Gets the Type of the current instance.(Inherited from Object) | 
| MemberwiseClone() | Creates a shallow copy of the current Object.(Inherited from Object) | 
| ToString() | Returns a string that represents the current object.(Inherited from Object) | 
Explicit Interface Implementations
| IDisposable.Dispose() | This API supports the product infrastructure and is not intended to be used directly from your code. Releases all resources used by the TcpClient. |