0

0

如何用c++实现一个简单的HTTP服务器 Boost.Beast库入门【网络编程】

冰火之心

冰火之心

发布时间:2025-12-24 17:32:02

|

834人浏览过

|

来源于php中文网

原创

boost.beast是基于boost.asio的轻量http/https库,纯头文件、无需编译,支持同步/异步模型;示例实现单线程http服务器,监听8080端口并返回html响应,需调用prepare_payload()设置长度或分块编码。

如何用c++实现一个简单的http服务器 boost.beast库入门【网络编程】

用 C++ 实现一个简单的 HTTP 服务器,Boost.Beast 是目前最实用、最贴近底层又足够易用的选择。它基于 Boost.Asio 构建,专为 HTTP/HTTPS 和 WebSocket 设计,不依赖外部 OpenSSL(可选),代码清晰,适合学习和轻量部署。

准备工作:环境与依赖

确保已安装 Boost 1.70 或更高版本(Beast 自 1.70 起正式集成进 Boost 主干)。不需要单独编译 Beast —— 它是纯头文件库,只要包含路径正确即可使用。

  • Linux/macOS:推荐用 Boost 1.84+(最新稳定版),通过包管理器或源码安装
  • Windows:可用 vcpkg:vcpkg install boost-beast
  • 编译时需链接 boost_system(Asio 底层依赖),命令示例:
    g++ -std=c++17 server.cpp -lboost_system -lpthread -o server

核心结构:同步 HTTP 服务器示例

以下是一个最小可运行的同步 HTTP 服务器(单线程、阻塞式),监听 8080 端口,返回固定 HTML 响应:

Reachout.ai
Reachout.ai

一个AI驱动的视频开发平台,专为忙碌的企业家和销售团队打造

下载
#include <boost/beast/core.hpp>
#include <boost/beast/http.hpp>
#include <boost/beast/version.hpp>
#include <boost/asio/ip/tcp.hpp>
#include <boost/asio.hpp>
#include <iostream>
#include <string>

namespace beast = boost::beast;
namespace http = beast::http;
namespace net = boost::asio;
using tcp = net::ip::tcp;

void handle_request(http::request<http::string_body>& req,
                    http::response<http::string_body>& res) {
    // 简单路由:只处理 GET /
    if (req.method() == http::verb::get && req.target() == "/") {
        res.result(http::status::ok);
        res.set(http::field::content_type, "text/html");
        res.body() = "<h1>Hello from Boost.Beast!</h1>";
        res.prepare_payload();
    } else {
        res.result(http::status::not_found);
        res.set(http::field::content_type, "text/plain");
        res.body() = "404 Not Found";
        res.prepare_payload();
    }
}

void do_session(tcp::socket& socket) {
    try {
        beast::flat_buffer buffer;
        http::request<http::string_body> req;
        http::read(socket, buffer, req);

        http::response<http::string_body> res;
        handle_request(req, res);

        http::write(socket, res);
    } catch (const std::exception& e) {
        std::cerr << "Error: " << e.what() << "\n";
    }
}

int main() {
    net::io_context ioc;
    tcp::acceptor acceptor(ioc, tcp::endpoint(tcp::v4(), 8080));

    while (true) {
        tcp::socket socket(ioc);
        acceptor.accept(socket);
        do_session(socket);
    }
}

关键点说明

  • beast::flat_buffer:高效内存缓冲区,避免频繁分配,必须传给 http::read
  • http::request / response 模板参数指定 body 类型,string_body 最常用;若需流式响应,可用 file_body 或自定义 body
  • res.prepare_payload():必须调用!它自动设置 Content-Length 或启用 chunked 编码
  • 同步 vs 异步:上面是同步版本(适合教学);生产环境建议用异步(async_read/async_write + `net::co_spawn` 协程更简洁)

下一步建议

  • do_session 改成异步函数,配合 net::co_spawn 实现协程式处理(C++20)
  • 添加静态文件服务:用 http::file_body 直接返回磁盘文件
  • 支持 POST 表单解析:读取 req.body() 或用 http::parser 分析 multipart
  • 加日志、连接超时、Keep-Alive 控制(设置 res.keep_alive(true)

不复杂但容易忽略:Beast 的 HTTP 类型是值语义,请求/响应对象默认不可重用,每次会话都应新建;同时注意 buffer 生命周期不能短于 read/write 调用。

立即学习C++免费学习笔记(深入)”;

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
length函数用法
length函数用法

length函数用于返回指定字符串的字符数或字节数。可以用于计算字符串的长度,以便在查询和处理字符串数据时进行操作和判断。 需要注意的是length函数计算的是字符串的字符数,而不是字节数。对于多字节字符集,一个字符可能由多个字节组成。因此,length函数在计算字符串长度时会将多字节字符作为一个字符来计算。更多关于length函数的用法,大家可以阅读本专题下面的文章。

952

2023.09.19

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

723

2023.08.10

windows查看端口占用情况
windows查看端口占用情况

Windows端口可以认为是计算机与外界通讯交流的出入口。逻辑意义上的端口一般是指TCP/IP协议中的端口,端口号的范围从0到65535,比如用于浏览网页服务的80端口,用于FTP服务的21端口等等。怎么查看windows端口占用情况呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

1356

2023.07.26

查看端口占用情况windows
查看端口占用情况windows

端口占用是指与端口关联的软件占用端口而使得其他应用程序无法使用这些端口,端口占用问题是计算机系统编程领域的一个常见问题,端口占用的根本原因可能是操作系统的一些错误,服务器也可能会出现端口占用问题。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

1159

2023.07.27

windows照片无法显示
windows照片无法显示

当我们尝试打开一张图片时,可能会出现一个错误提示,提示说"Windows照片查看器无法显示此图片,因为计算机上的可用内存不足",本专题为大家提供windows照片无法显示相关的文章,帮助大家解决该问题。

827

2023.08.01

windows查看端口被占用的情况
windows查看端口被占用的情况

windows查看端口被占用的情况的方法:1、使用Windows自带的资源监视器;2、使用命令提示符查看端口信息;3、使用任务管理器查看占用端口的进程。本专题为大家提供windows查看端口被占用的情况的相关的文章、下载、课程内容,供大家免费下载体验。

460

2023.08.02

windows无法访问共享电脑
windows无法访问共享电脑

在现代社会中,共享电脑是办公室和家庭的重要组成部分。然而,有时我们可能会遇到Windows无法访问共享电脑的问题。这个问题可能会导致数据无法共享,影响工作和生活的正常进行。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

2361

2023.08.08

windows自动更新
windows自动更新

Windows操作系统的自动更新功能可以确保系统及时获取最新的补丁和安全更新,以提高系统的稳定性和安全性。然而,有时候我们可能希望暂时或永久地关闭Windows的自动更新功能。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

854

2023.08.10

Golang 测试体系与代码质量保障:工程级可靠性建设
Golang 测试体系与代码质量保障:工程级可靠性建设

Go语言测试体系与代码质量保障聚焦于构建工程级可靠性系统。本专题深入解析Go的测试工具链(如go test)、单元测试、集成测试及端到端测试实践,结合代码覆盖率分析、静态代码扫描(如go vet)和动态分析工具,建立全链路质量监控机制。通过自动化测试框架、持续集成(CI)流水线配置及代码审查规范,实现测试用例管理、缺陷追踪与质量门禁控制,确保代码健壮性与可维护性,为高可靠性工程系统提供质量保障。

48

2026.02.28

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 10万人学习

Git 教程
Git 教程

共21课时 | 3.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号