Open In App

Socket Programming in C++

In C++, socket programming refers to the method of communication between two sockets on the network using a C++ program. We use the socket API to create a connection between the two programs running on the network, one of which receives the data by listening to the particular address port, and the other sends the data. One of the features of the socket programming is that it allows the bidirectional communication between the nodes.

In this article, we will create some simple C++ programs to demonstrate the use of socket programming.



What are Sockets?

Sockets can be viewed as the endpoint of the two-way communication between the two programming in the network. They are generally hosted on different application ports and allow bidirectional data transfer.

Types of Sockets

There are two main types of sockets:



Server Stages

1. Creating the Server Socket

We create socket by using the socket() system call. It is defined inside the <sys/socket.h> header file.

Syntax

int serverSocket = socket(AF_INET, SOCK_STREAM, 0);

here,

2. Defining Server Address

We then define the server address using the following set of statements

sockaddr_in serverAddress;
serverAddress.sin_family = AF_INET;
serverAddress.sin_port = htons(8080);
serverAddress.sin_addr.s_addr = INADDR_ANY;

here,

3. Binding the Server Socket

Then we bind the socket using the bind() call as shown.

bind(serverSocket, (struct sockaddr*)&serverAddress, sizeof(serverAddress));

4. Listening for Connections

We then tell the application to listen to the socket refffered by the serverSocket.

listen(serverSocket, 5);

5. Accepting a Client Connection

The accept() call is used to accept the connection request that is recieved on the socket the application was listening to.

int clientSocket = accept(serverSocket, nullptr, nullptr);

6. Receiving Data from the Client

Then we start receiving the data from the client. We can specify the required buffer size so that it has enough space to receive the data sent the the client. The example of this is shown below.

char buffer[1024] = {0};
recv(clientSocket, buffer, sizeof(buffer), 0);
cout << "Message from client: " << buffer << endl;

7. Closing the Server Socket

We close the socket using the close() call and the associated socket descriptor.

close(serverSocket);

Client Stages

Similar to server, we also have to create a socket and specify the address. But instead of accepting request, we send the connection request when we can to sent the data using connect() call.

Then we sent the data using send() call. After all the operations are done, we close the connection using close() call.

1. Creating the Client Socket

int clientSocket = socket(AF_INET, SOCK_STREAM, 0);

2. Defining Server Address

sockaddr_in serverAddress;
serverAddress.sin_family = AF_INET;
serverAddress.sin_port = htons(8080);
serverAddress.sin_addr.s_addr = INADDR_ANY;

3. Connecting to the Server

connect(clientSocket, (struct sockaddr*)&serverAddress, sizeof(serverAddress));

4. Sending Data to the Server

const char* message = "Hello, server!";
send(clientSocket, message, strlen(message), 0);

5. Closing the Client Socket

close(clientSocket);

Example of Socket Programming in C++

server.cpp




// C++ program to show the example of server application in
// socket programming
#include <cstring>
#include <iostream>
#include <netinet/in.h>
#include <sys/socket.h>
#include <unistd.h>
  
using namespace std;
  
int main()
{
    // creating socket
    int serverSocket = socket(AF_INET, SOCK_STREAM, 0);
  
    // specifying the address
    sockaddr_in serverAddress;
    serverAddress.sin_family = AF_INET;
    serverAddress.sin_port = htons(8080);
    serverAddress.sin_addr.s_addr = INADDR_ANY;
  
    // binding socket.
    bind(serverSocket, (struct sockaddr*)&serverAddress,
         sizeof(serverAddress));
  
    // listening to the assigned socket
    listen(serverSocket, 5);
  
    // accepting connection request
    int clientSocket
        = accept(serverSocket, nullptr, nullptr);
  
    // recieving data
    char buffer[1024] = { 0 };
    recv(clientSocket, buffer, sizeof(buffer), 0);
    cout << "Message from client: " << buffer
              << endl;
  
    // closing the socket.
    close(serverSocket);
  
    return 0;
}

client.cpp




// C++ program to illustrate the client application in the
// socket programming
#include <cstring>
#include <iostream>
#include <netinet/in.h>
#include <sys/socket.h>
#include <unistd.h>
  
int main()
{
    // creating socket
    int clientSocket = socket(AF_INET, SOCK_STREAM, 0);
  
    // specifying address
    sockaddr_in serverAddress;
    serverAddress.sin_family = AF_INET;
    serverAddress.sin_port = htons(8080);
    serverAddress.sin_addr.s_addr = INADDR_ANY;
  
    // sending connection request
    connect(clientSocket, (struct sockaddr*)&serverAddress,
            sizeof(serverAddress));
  
    // sending data
    const char* message = "Hello, server!";
    send(clientSocket, message, strlen(message), 0);
  
    // closing socket
    close(clientSocket);
  
    return 0;
}

By compiling and running server and client source files, we get the following output.

Output

As we can see, the message we sent to the server at port 8080 is revived and printed by the server. We can also create a loop where we can keep sending the messages to the server.

Application and Benefits

Real-world Applications

Socket programming finds applications in a myriad of scenarios, from fundamental client-server interactions to intricate distributed systems. Its versatility powers web servers, chat applications, file transfer protocols and online gaming platforms.

Advantages of Socket Programming

Talking in Different Languages: Sockets help programs written in different languages understand each other.

Fast and Efficient Communication: They enable direct communication, making data exchange quicker.

Handling Many Users: Sockets let applications handle many users at the same time, like a busy chat room.


Article Tags :