117.info
人生若只如初见

CentOS中C++网络编程如何实现

在CentOS系统中进行C++网络编程,通常会使用套接字(socket)API。以下是一个简单的TCP服务器和客户端的示例,展示了如何在CentOS上使用C++进行网络编程。

1. 安装必要的开发工具

首先,确保你已经安装了gccmake等开发工具。如果没有安装,可以使用以下命令进行安装:

sudo yum groupinstall "Development Tools"

2. 编写TCP服务器代码

创建一个名为tcp_server.cpp的文件,并添加以下代码:

#include 
#include 
#include 
#include 
#include 

#define PORT 8080

int main() {
    int server_fd, new_socket;
    struct sockaddr_in address;
    int opt = 1;
    int addrlen = sizeof(address);
    char buffer[1024] = {0};
    const char* hello = "Hello from server";

    // Creating socket file descriptor
    if ((server_fd = socket(AF_INET, SOCK_STREAM, 0)) == 0) {
        perror("socket failed");
        exit(EXIT_FAILURE);
    }

    // Forcefully attaching socket to the port 8080
    if (setsockopt(server_fd, SOL_SOCKET, SO_REUSEADDR | SO_REUSEPORT, &opt, sizeof(opt))) {
        perror("setsockopt");
        exit(EXIT_FAILURE);
    }

    address.sin_family = AF_INET;
    address.sin_addr.s_addr = INADDR_ANY;
    address.sin_port = htons(PORT);

    // Forcefully attaching socket to the port 8080
    if (bind(server_fd, (struct sockaddr*)&address, sizeof(address)) < 0) {
        perror("bind failed");
        exit(EXIT_FAILURE);
    }

    if (listen(server_fd, 3) < 0) {
        perror("listen");
        exit(EXIT_FAILURE);
    }

    if ((new_socket = accept(server_fd, (struct sockaddr*)&address, (socklen_t*)&addrlen)) < 0) {
        perror("accept");
        exit(EXIT_FAILURE);
    }

    read(new_socket, buffer, 1024);
    std::cout << buffer << std::endl;
    send(new_socket, hello, strlen(hello), 0);
    std::cout << "Hello message sent\n";

    close(new_socket);
    close(server_fd);

    return 0;
}

3. 编译服务器代码

使用g++编译服务器代码:

g++ -o tcp_server tcp_server.cpp

4. 运行服务器

在终端中运行服务器:

./tcp_server

服务器将在端口8080上监听连接。

5. 编写TCP客户端代码

创建一个名为tcp_client.cpp的文件,并添加以下代码:

#include 
#include 
#include 
#include 
#include 

#define PORT 8080

int main() {
    struct sockaddr_in serv_addr;
    int sock = 0;
    const char* hello = "Hello from client";
    char buffer[1024] = {0};

    if ((sock = socket(AF_INET, SOCK_STREAM, 0)) < 0) {
        std::cout << "\n Socket creation error \n";
        return -1;
    }

    serv_addr.sin_family = AF_INET;
    serv_addr.sin_port = htons(PORT);

    // Convert IPv4 and IPv6 addresses from text to binary form
    if (inet_pton(AF_INET, "127.0.0.1", &serv_addr.sin_addr) <= 0) {
        std::cout << "\nInvalid address/ Address not supported \n";
        return -1;
    }

    if (connect(sock, (struct sockaddr*)&serv_addr, sizeof(serv_addr)) < 0) {
        std::cout << "\nConnection Failed \n";
        return -1;
    }

    send(sock, hello, strlen(hello), 0);
    std::cout << "Hello message sent\n";
    read(sock, buffer, 1024);
    std::cout << "Server: " << buffer << std::endl;

    close(sock);

    return 0;
}

6. 编译客户端代码

使用g++编译客户端代码:

g++ -o tcp_client tcp_client.cpp

7. 运行客户端

在另一个终端中运行客户端:

./tcp_client

客户端将连接到服务器,发送消息并接收服务器的响应。

总结

以上是一个简单的TCP服务器和客户端的示例,展示了如何在CentOS上使用C++进行网络编程。你可以根据需要扩展和修改这些示例,以实现更复杂的网络应用程序。

未经允许不得转载 » 本文链接:https://www.117.info/ask/feedaAzsNAAJWBFA.html

推荐文章

  • CentOS下MinIO安装步骤是什么

    在CentOS下安装MinIO的步骤如下:
    1. 集群节点规划 确定节点IP地址和目录结构,例如: 192.168.10.101 minio server/data/minio_data/{data1,data2}
    1...

  • centos挂载时出现权限问题如何解决

    当在CentOS系统挂载磁盘时遇到权限问题,可以尝试以下几种方法来解决:
    检查挂载点的权限
    确保挂载点存在并具有正确的权限。可以使用以下命令来创建挂...

  • 如何在centos上配置java代理

    在CentOS上配置Java代理,可以通过以下几种方法:
    方法一:通过环境变量配置 临时设置代理:
    打开终端,输入以下命令来设置HTTP和HTTPS代理:
    ex...

  • centos SFTP配置中如何使用公钥认证

    在CentOS系统中配置SFTP以使用公钥认证,可以按照以下步骤进行:
    1. 生成SSH密钥对
    首先,你需要在客户端生成一个SSH密钥对。如果你还没有密钥对,可以...

  • debian中gcc的性能调优有哪些方法

    在Debian系统中,GCC(GNU编译器集合)的性能调优可以通过多种方法实现。以下是一些常见的调优策略: 优化级别: 使用-O选项来指定优化级别。例如,-O2会进行大多...

  • SQL Server在Debian上的备份恢复工具有哪些

    在Debian系统上,虽然没有专门为SQL Server设计的备份恢复工具,但可以使用一些通用的数据库备份工具来实现SQL Server的备份和恢复功能。以下是一些可用的工具:...

  • 如何优化Linux上Informix的内存使用

    优化Linux上Informix的内存使用可以通过以下几个步骤进行: 监控内存使用情况: 使用 free -m 命令查看当前系统的内存使用情况,包括总内存、已使用内存、剩余内...

  • Debian下Zookeeper安全设置

    在Debian系统下配置Zookeeper的安全设置主要包括配置ACL(访问控制列表)、创建用户和角色、以及客户端连接时使用认证信息。以下是详细的步骤:
    配置ACL(访...