【C++】开源:Boost网络库Asio配置使用

😏*★,°* :.☆( ̄▽ ̄)/$:.°★ 😏

这篇文章主要介绍Asio网络库配置使用。
无专精则不能成,无涉猎则不能通。------梁启超

欢迎来到我的博客,一起学习,共同进步。

喜欢的朋友可以关注一下,下次更新不迷路🥞

文章目录

    • [:smirk:1. 项目介绍](#:smirk:1. 项目介绍)
    • [:blush:2. 环境配置](#:blush:2. 环境配置)
    • [:satisfied:3. 使用说明](#:satisfied:3. 使用说明)

😏1. 项目介绍

项目Github地址:https://github.com/boostorg/asio

Boost.Asio是一个用于网络和底层I/O编程的C++库,它提供了一种简洁而高效的方式来处理异步事件驱动的网络编程。Asio是"异步 I/O"的缩写。

下面是一些关于Boost.Asio的特点和功能的介绍:

1.异步模型:Boost.Asio使用异步编程模型,允许你以非阻塞的方式处理多个并发的I/O操作。这样可以提高程序的性能和响应能力。
2.跨平台性:Boost.Asio在不同操作系统上提供统一的API,使得你可以在多个平台上轻松开发和移植网络应用程序。
3.支持多种协议:Boost.Asio支持多种网络协议,包括TCP、UDP、SSL等,让你能够轻松地进行各种网络通信。
4.网络编程基础功能:Boost.Asio提供了一系列的类和函数,用于处理套接字、地址解析、定时器、缓冲区等常见的网络编程任务。
5.可扩展性:Boost.Asio提供了灵活的接口和设计,允许你根据需要对其进行扩展和定制,以满足特定的应用需求。
6.高性能:Boost.Asio通过使用异步I/O、事件驱动和零拷贝等技术,可以实现高效的网络编程,提供出色的性能。

Boost.Asio是一个功能强大而灵活的库,它被广泛应用于构建各种类型的网络应用程序,包括Web服务器、游戏服务器、实时通信系统等。它不仅提供了一种简单易用的方式来处理网络编程任务,还允许你利用C++的强大功能来开发高性能和可扩展的应用程序。

😊2. 环境配置

下面进行环境配置:

bash 复制代码
# apt安装
sudo apt-get install libboost-dev libasio-dev

😆3. 使用说明

下面进行使用分析:

TCP-Http客户端请求示例:

cpp 复制代码
#include <iostream>
#include <boost/asio.hpp>

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

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

        // 创建一个 TCP socket
        tcp::socket socket(io_context);

        // 连接到服务器
        tcp::resolver resolver(io_context);
        boost::asio::connect(socket, resolver.resolve("www.example.com", "http"));

        // 发送 HTTP 请求
        std::string request = "GET / HTTP/1.1\r\n"
                              "Host: www.example.com\r\n"
                              "Connection: close\r\n\r\n";
        boost::asio::write(socket, boost::asio::buffer(request));

        // 读取响应数据
        boost::asio::streambuf response;
        boost::asio::read_until(socket, response, "\r\n");

        // 打印响应数据
        std::istream response_stream(&response);
        std::string status_line;
        std::getline(response_stream, status_line);
        std::cout << "Response: " << status_line << std::endl;

        // 关闭连接
        socket.close();
    }
    catch (std::exception& e)
    {
        std::cerr << "Exception: " << e.what() << std::endl;
    }

    return 0;
}

编译运行:

bash 复制代码
g++ -o main main.cpp -lboost_system -lpthread
Response: HTTP/1.1 200 OK

TCP服务端示例:

cpp 复制代码
#include <iostream>
#include <boost/asio.hpp>

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

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

        // 创建一个 TCP acceptor,监听指定端口
        tcp::acceptor acceptor(io_context, tcp::endpoint(tcp::v4(), 8080));

        // 等待并接受连接
        tcp::socket socket(io_context);
        acceptor.accept(socket);

        // 处理连接请求
        std::string message = "Hello, Boost.Asio!";
        boost::system::error_code ignored_error;
        boost::asio::write(socket, boost::asio::buffer(message), ignored_error);
    }
    catch (std::exception& e)
    {
        std::cerr << "Exception: " << e.what() << std::endl;
    }

    return 0;
}

编译运行:

bash 复制代码
g++ -o server server.cpp -lboost_system -lpthread
./server

TCP客户端示例:

cpp 复制代码
#include <iostream>
#include <boost/asio.hpp>

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

int main() {
  try {
    // 创建IO上下文对象
    boost::asio::io_context io_context;

    // 创建socket对象
    tcp::socket socket(io_context);

    // 解析服务器地址和端口
    tcp::resolver resolver(io_context);
    tcp::resolver::results_type endpoints = resolver.resolve("127.0.0.1", "8080");

    // 连接到服务器
    boost::asio::connect(socket, endpoints);

    // 发送数据给服务器
    std::string request = "Hello, server!";
    boost::asio::write(socket, boost::asio::buffer(request));

    // 接收服务器的响应
    char response[1024];
    size_t bytesRead = socket.read_some(boost::asio::buffer(response));

    // 显示服务器的响应
    std::cout << "Response from server: ";
    std::cout.write(response, bytesRead);
    std::cout << std::endl;

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

  return 0;
}

编译运行:

bash 复制代码
g++ -o client client.cpp -lboost_system -lpthread
./client
Response from server: Hello, Boost.Asio!

以上。

相关推荐
数据与人工智能律师5 分钟前
解码Web3:DeFi、GameFi、SocialFi的法律风险警示与合规路径
大数据·网络·人工智能·云计算·区块链
NocoBase6 分钟前
俄罗斯合作伙伴 Mobx,用 NocoBase 交付多场景方案
低代码·开源·资讯
xingxing_F18 分钟前
Network Radar for Mac 网络扫描管理软件
网络·macos
wanhengidc22 分钟前
巨椰云手机引领未来
运维·服务器·网络·游戏·智能手机
九河云1 小时前
TOS + 数字孪生:集装箱码头的智能进化密码
大数据·服务器·网络·数据库·数字化转型
尘世中一位迷途小书童1 小时前
🎨 SCSS 高级用法完全指南:从入门到精通
前端·css·开源
艾莉丝努力练剑1 小时前
【C++STL :stack && queue (一) 】STL:stack与queue全解析|深入使用(附高频算法题详解)
linux·开发语言·数据结构·c++·算法
MonkeyKing_sunyuhua1 小时前
python线程间怎么通信
android·网络·python
沐浴露z1 小时前
一篇文章讲清 UPD协议 与 TCP协议
网络·网络协议·tcp/ip·计算机网络
胡萝卜3.01 小时前
深入理解string底层:手写高效字符串类
开发语言·c++·学习·学习笔记·string类·string模拟实现