使用C++编写TCP服务端程序

要使用Boost.Asio库来开发一个TCP服务端程序,你需要遵循以下步骤。下面的示例代码将演示如何创建一个简单的异步TCP服务器,它能够接收客户端连接,并异步处理请求和响应。

首先,确保你已经安装了Boost库,并在你的项目中包含了asio库。

以下是基本的代码框架:

cpp 复制代码
#include <boost/asio.hpp>
#include <boost/bind.hpp>
#include <boost/system/error_code.hpp>
#include <iostream>
#include <memory>

using boost::asio::ip::tcp;

class Server {
public:
    Server(boost::asio::io_context& io_context, short port)
        : acceptor_(io_context, tcp::endpoint(tcp::v4(), port))
    {
        // 启动监听
        start_accept();
    }

private:
    void start_accept() {
        // 创建新的socket
        std::shared_ptr<tcp::socket> new_socket = std::make_shared<tcp::socket>(acceptor_.get_executor().context());

        // 异步接受连接
        acceptor_.async_accept(*new_socket,
            [this, new_socket](boost::system::error_code ec) {
                if (!ec) {
                    std::cout << "New connection accepted." << std::endl;
                    // 异步读取请求数据
                    boost::asio::async_read(*new_socket, boost::asio::buffer(buffer_),
                        [this, new_socket](boost::system::error_code ec, std::size_t length) {
                            if (!ec) {
                                // 处理请求(这里只是简单地将接收到的数据原样返回)
                                boost::asio::async_write(*new_socket, boost::asio::buffer(buffer_, length),
                                    [new_socket](boost::system::error_code ec, std::size_t /*length*/) {
                                        if (ec) {
                                            std::cerr << "Error: " << ec.message() << std::endl;
                                        } else {
                                            std::cout << "Response sent successfully." << std::endl;
                                        }
                                    });
                            } else {
                                std::cerr << "Read failed: " << ec.message() << std::endl;
                            }
                        });

                    // 继续监听下一个连接
                    start_accept();
                } else {
                    std::cerr << "Accept failed: " << ec.message() << std::endl;
                }
            });
    }

    tcp::acceptor acceptor_;
    char buffer_[1024];
};

int main() {
    try {
        boost::asio::io_context io_context;

        Server s(io_context, 12345);

        io_context.run();
    }
    catch (std::exception& e) {
        std::cerr << e.what() << std::endl;
    }

    return 0;
}

在这个例子中:

  • 我们定义了一个Server类,它包含一个acceptor用于接受新连接。
  • start_accept函数用于启动异步接受过程,当有新的连接到达时,它会创建一个新的socket并绑定到一个lambda函数中,该函数处理读取请求、处理请求以及写入响应。
  • 请求数据被读取到buffer_中,然后原样返回给客户端。
  • 使用io_context.run()启动事件循环,处理所有的I/O操作。
相关推荐
tankeven9 分钟前
HJ178 【模板】双指针
c++·算法
杨云龙UP26 分钟前
ODA-Oracle实践记录:通过Navicat导出导入表CSV文件并清理重复数据,处理OA待办延迟刷新问题_20260416
linux·运维·服务器·数据库·sql·mysql·oracle
Andya_net34 分钟前
网络安全 | NPing网络包生成工具详解
网络·安全·web安全
charlie11451419138 分钟前
嵌入式C++工程实践——第13篇:第一次重构 —— enum class取代宏,类型安全的开始
开发语言·c++·vscode·stm32·安全·重构·现代c++
徒 花38 分钟前
HCIP学习19 BGP 跨自治系统互通综合实验
网络·学习·智能路由器·hcip·ensp
易连EDI—EasyLink43 分钟前
易连EDI EasyLink:新OFTP2安全算法 RSA-PSS、RSA-OAEP、SHA3-512筑牢企业EDI传输安全防线
网络·人工智能·安全·edi·电子数据交换·as2
CHANG_THE_WORLD1 小时前
C++ 文件读取函数完全指南
开发语言·c++
6Hzlia1 小时前
【Hot 100 刷题计划】 LeetCode 300. 最长递增子序列 | C++ 动态规划 & 贪心二分
c++·leetcode·动态规划
阿正的梦工坊1 小时前
JavaScript 闭包 × C++ 类比:彻底搞懂闭包
开发语言·javascript·c++
6Hzlia1 小时前
【Hot 100 刷题计划】 LeetCode 72. 编辑距离 | C++ 经典 DP 增删改状态转移
c++·算法·leetcode