【C++】httplib:轻量级的 HTTP 服务器和客户端

news2025/3/31 6:49:03

本教程采用渐进式讲解方式,适用于 MinGW 环境。我们将从 httplib 的基本概念入手,通过一个小型 Demo 展示其核心用法,最后深入探讨高级功能与实际应用场景。


1. 简介

1.1 httplib 基本概念

httplib 是一个轻量级的 C++ HTTP 库,设计初衷是为嵌入式系统和资源受限环境提供简洁高效的 HTTP 支持。它是一个单头文件库(httplib.h),无需外部依赖,支持创建 HTTP 服务器和客户端,并兼容 HTTP/1.1 协议。httplib 的主要特点包括:

  • 无外部依赖:只需包含头文件即可使用,无需额外的库文件。
  • 跨平台:支持 Windows、Linux 和 macOS 等操作系统。
  • 简单易用:提供直观的 API,开发者可以快速实现 HTTP 请求和响应的处理。
  • 支持 SSL/TLS:通过集成 OpenSSL,可以启用 HTTPS 功能。

在 MinGW 环境下,编译时可能需要链接 ws2_32 库(视具体实现而定),方法是在编译命令中添加 -lws2_32 参数。也可以通过静态链接 MinGW 库来避免运行时依赖动态库。具体的编译命令如下:

g++ -o main.exe main.cpp -lws2_32 -static-libgcc -static-libstdc++ -Wl,-Bstatic -lstdc++ -lpthread
  • static-libgcc:静态链接 GCC 运行时库。
  • static-libstdc++:静态链接 C++ 标准库。
  • Wl,-Bstatic -lstdc++ -lpthread:确保标准库和线程库也以静态方式链接。

1.2 获取 httplib

由于 httplib 是头文件库,安装非常简单。你可以从其官方 GitHub 仓库(https://github.com/yhirose/cpp-httplib)下载最新版本的 httplib.h,然后将其放入项目目录,并在代码中通过以下方式包含:

#include "httplib.h"

接下来,我们将通过一个简单的 Demo 展示 httplib 的核心用法。


2. 快速入门:一个小型 Demo

为了让你快速上手,我们将编写一个 HTTP 服务器和客户端的示例。服务器监听本地 8080 端口并返回简单消息,客户端则向服务器发送请求并打印响应。

2.1 HTTP 服务器 Demo

以下是一个简单的 HTTP 服务器实现:

#include "httplib.h"
#include <iostream>

int main() {
    // 创建 HTTP 服务器
    httplib::Server svr;

    // 定义根路径的 GET 请求处理
    svr.Get("/", [](const httplib::Request& req, httplib::Response& res) {
        res.set_content("Hello, World!", "text/plain");
    });

    // 启动服务器,监听 localhost:8080
    std::cout << "Server started at http://localhost:8080" << std::endl;
    svr.listen("localhost", 8080);

    return 0;
}

编译命令

g++ -o server server.cpp -lws2_32

代码说明

  1. httplib::Server 创建服务器实例。
  2. svr.Get 定义了对 / 路径的 GET 请求处理,返回纯文本 “Hello, World!”。
  3. svr.listen 启动服务器,监听指定地址和端口。

2.2 HTTP 客户端 Demo

以下是对应的客户端代码:

#include "httplib.h"
#include <iostream>

int main() {
    // 创建 HTTP 客户端,连接 localhost:8080
    httplib::Client cli("localhost", 8080);

    // 发送 GET 请求
    auto res = cli.Get("/");

    // 检查并输出响应
    if (res && res->status == 200) {
        std::cout << "Response: " << res->body << std::endl;
    } else {
        std::cout << "Request failed" << std::endl;
    }

    return 0;
}

编译命令

g++ -o client client.cpp -lws2_32

代码说明

  1. httplib::Client 创建客户端实例,指定服务器地址和端口。
  2. cli.Get 发送 GET 请求到 / 路径。
  3. 检查响应对象 res,确保请求成功(状态码 200),并输出响应正文。

2.3 运行 Demo

  1. 打开一个终端,运行服务器:

    ./server
    

    你将看到提示 “Server started at http://localhost:8080”。

  2. 打开另一个终端,运行客户端:

    ./client
    

    客户端将输出 “Response: Hello, World!”。

通过这个 Demo,你已经掌握了 httplib 创建服务器和客户端的基本流程。接下来,我们将深入探讨其高级功能。


3. 深入探讨:高级功能与实际应用

在快速入门中,我们了解了 httplib 的基础用法。现在,我们将探索其高级功能,并展示如何在实际项目中应用这些特性。

3.1 HTTP 服务器高级功能

3.1.1 路由和参数化路径

httplib 支持多种 HTTP 方法(GET、POST、PUT、DELETE 等),并允许为不同路径设置处理函数。以下是一个示例,展示如何处理参数化路径和 POST 请求:

svr.Get("/user/:id", [](const httplib::Request& req, httplib::Response& res) {
    auto id = req.path_params.at("id"); // 获取路径参数
    res.set_content("User ID: " + id, "text/plain");
});

svr.Post("/submit", [](const httplib::Request& req, httplib::Response& res) {
    auto data = req.body; // 获取 POST 数据
    res.set_content("Received: " + data, "text/plain");
});

访问 /user/123 将返回 “User ID: 123”。

3.1.2 静态文件服务

httplib 可以将本地目录映射为静态文件服务。例如:

svr.set_mount_point("/", "./www");

假设 ./www 目录下有 index.html,访问 http://localhost:8080/index.html 将返回该文件内容。

3.1.3 SSL/TLS 支持

要启用 HTTPS,需要使用 httplib::SSLServer 并提供证书和私钥:

httplib::SSLServer svr("cert.pem", "key.pem");
svr.Get("/", [](const httplib::Request& req, httplib::Response& res) {
    res.set_content("Hello, HTTPS!", "text/plain");
});
svr.listen("localhost", 443);

注意:编译时需链接 OpenSSL 库(-lssl -lcrypto),并确保 MinGW 环境支持 OpenSSL。

3.2 HTTP 客户端高级功能

3.2.1 发送多种请求

客户端支持 GET、POST、PUT、DELETE 等请求。例如:

// POST 请求
auto res = cli.Post("/submit", "data", "text/plain");

// PUT 请求
auto res = cli.Put("/update", "new data", "text/plain");

// DELETE 请求
auto res = cli.Delete("/delete");
3.2.2 设置请求头

可以通过 httplib::Headers 设置自定义请求头:

httplib::Headers headers = {{"Authorization", "Bearer token"}};
auto res = cli.Get("/", headers);
3.2.3 HTTPS 支持

客户端支持 HTTPS 请求:

httplib::SSLClient cli("localhost", 443);
auto res = cli.Get("/");

同样需要 OpenSSL 支持。

3.3 实际应用场景

3.3.1 RESTful API 服务器

httplib 非常适合构建 RESTful API。例如:

svr.Get("/api/users", [](const httplib::Request& req, httplib::Response& res) {
    res.set_content("[{\"id\":1,\"name\":\"Alice\"}]", "application/json");
});

svr.Post("/api/users", [](const httplib::Request& req, httplib::Response& res) {
    res.set_content("User created", "text/plain");
});
3.3.2 微服务通信

在微服务架构中,httplib 可用于服务间通信:

// 服务 A(客户端)
httplib::Client cli("service-b", 8080);
auto res = cli.Get("/data");

// 服务 B(服务器)
svr.Get("/data", [](const httplib::Request& req, httplib::Response& res) {
    res.set_content("Data from Service B", "text/plain");
});

4. 总结

通过本教程,你已经全面了解了 C++ httplib 的功能。从基础概念到快速入门 Demo,再到高级功能和实际应用,httplib 展示了其轻量、灵活和强大的特性。在 MinGW 环境下使用时,建议链接 ws2_32 库以确保兼容性(视具体需求而定)。希望这篇教程能帮助你在项目中高效使用 httplib!


以上是修改后的完整教程,去掉了 Winsock 相关内容。如果你还有其他需求或测试中发现新的调整点,请随时告诉我!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2323416.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

2025年移动端开发性能优化实践与趋势分析

启动速度优化 本质&#xff1a;缩短首次可见帧渲染时间。 方法&#xff1a; iOS&#xff1a;利用Core ML本地模型轻量化部署&#xff0c;减少云端等待。Android&#xff1a;强制启用SplashScreen API&#xff0c;通过setKeepOnScreenCondition控制动画时长。冷启动需将耗时操…

Docker Compose介绍

基本概念 Docker-Compose是Docker官方的开源项目&#xff0c;负责实现对docker容器集群的快速编排。 可以这么理解&#xff0c;docker compose是docker提出的一个工具软件&#xff0c;可以管理多个docker容器组成一个应用&#xff0c;只需要编写一个YAML格式的配置文件docker…

头歌实践教学平台--【数据库概论】--SQL

一、表结构与完整性约束的修改(ALTER) 1.修改表名 USE TestDb1; alter table your_table rename TO my_table; 2.添加与删除字段 #语句1&#xff1a;删除表orderDetail中的列orderDate alter table orderDetail drop orderDate; #语句2&#xff1a;添加列unitPrice alter t…

算法基础——模拟

目录 1 多项式输出 2.蛇形方阵 3.字符串的展开 模拟&#xff0c;顾名思义&#xff0c;就是题⽬让你做什么你就做什么&#xff0c;考察的是将思路转化成代码的代码能⼒。这类题⼀般较为简单&#xff0c;属于竞赛⾥⾯的签到题&#xff08;但是&#xff0c;万事⽆绝对&#xff…

【第30节】MFC编程:ListCtrl控件和TreeCtrl控件

目录 引言 一、高级控件ListCtrl 二、高级控件TreeCtrl 三、Shell控件 四、CImageList 五、综合代码示例 引言 在MFC编程里&#xff0c;高级控件能大幅提升应用程序的交互性与功能性。接下来&#xff0c;咱们会详细讲讲ListCtrl和TreeCtrl这两个高级控件。不仅会介绍它们…

JavaScript 手写 call、apply、bind 和 new

1. 手写 call 方法 核心思路&#xff1a;改变函数的 this 指向并立即执行&#xff0c;通过将函数临时挂载到目标对象上调用。 Function.prototype.myCall function (context, ...args) {// 如果 context 为 null 或 undefined&#xff0c;则默认为 windowcontext context |…

计算机网络基础:量子通信技术在网络中的应用前景

计算机网络基础:量子通信技术在网络中的应用前景 一、前言二、量子通信技术基础2.1 量子通信的基本概念2.2 量子通信的主要原理2.2.1 量子密钥分发(QKD)原理2.2.2 量子隐形传态原理三、量子通信技术的特点3.1 绝对安全性3.2 超高通信速率潜力3.3 抗干扰能力强四、量子通信技…

Postman 下载文件指南:如何请求 Excel/PDF 文件?

在 Postman 中进行 Excel/PDF 文件的请求下载和导出&#xff0c;以下是简明的步骤&#xff0c;帮助你轻松完成任务。首先&#xff0c;我们将从新建接口开始&#xff0c;逐步引导你完成整个过程。 Postman 请求下载/导出 excel/pdf 文件教程

Stereolabs ZED Box Mini:机器人与自动化领域的人工智能视觉新选择

在人工智能视觉技术快速发展的今天&#xff0c;其应用场景正在持续拓宽&#xff0c;从智能安防到工业自动化&#xff0c;从机器人技术到智能交通&#xff0c;各领域都在积极探索如何利用这一先进技术。而 Stereolabs 推出的ZED Box Mini&#xff0c;正是一款专为满足这些多样化…

arm之s3c2440的I2C的用法

基础概念 IC&#xff08;Inter-Integrated Circuit&#xff09;又称I2C&#xff0c;是是IICBus简称&#xff0c;所以中文应该叫集成电路总线。 IIC的总线的使用场景&#xff0c;所有挂载在IIC总线上的设备都有两根信号线&#xff0c;一根是数据线SDA&#xff0c;另一 根是时钟…

redis部署架构

一.redis多实例 如上图所示&#xff0c;我们经常使用实例的端口号来作为实例的安装目录名称。 1.创建实例安装目录 如上图所示&#xff0c;这是创建实例的安装目录&#xff0c; 2.拷贝实例的配置文件 如上图所示&#xff0c;将redis解压目录下的配置文件拷贝到对应的conf目录…

深入理解指针(4)(C语言版)

文章目录 前言一、回调函数是什么&#xff08;一&#xff09;定义&#xff08;二&#xff09;工作原理&#xff08;三&#xff09;应用场景 二、qsort举例&#xff08;一&#xff09;qsort函数简介&#xff08;二&#xff09;比较函数的定义&#xff08;三&#xff09;使用示例…

【HTML】验证与调试工具

个人主页&#xff1a;Guiat 归属专栏&#xff1a;HTML CSS JavaScript 文章目录 1. HTML 验证工具概述1.1 验证的重要性1.2 常见 HTML 错误类型 2. W3C 验证服务2.1 W3C Markup Validation Service2.2 使用 W3C 验证器2.3 验证结果解读 3. 浏览器开发者工具3.1 Chrome DevTools…

​​SenseGlove与Aeon Robotics携手推出HEART项目,助力机器人培训迈向新台阶

在自动化和机器人技术快速发展的今天&#xff0c;SenseGlove和Aeon Robotics联合推出了一项创新项目——HEART项目。该项目在欧盟资助的MasterXR框架内展开&#xff0c;旨在通过整合虚拟现实&#xff08;VR&#xff09;、力反馈触觉手套&#xff08;SenseGlove项目Rembrandt&am…

mapbox进阶,仿照百度,加载marker点位,移入marker点切换图标,点击展示气泡,气泡和marker联动

👨‍⚕️ 主页: gis分享者 👨‍⚕️ 感谢各位大佬 点赞👍 收藏⭐ 留言📝 加关注✅! 👨‍⚕️ 收录于专栏:mapbox 从入门到精通 文章目录 一、🍀前言1.1 ☘️mapboxgl.Map 地图对象1.2 ☘️mapboxgl.Map style属性1.3 ☘️marker 标注点位 api1.3.1 ☘️构造函数…

使用HTML5和CSS3实现3D旋转相册效果

使用HTML5和CSS3实现3D旋转相册效果 这里写目录标题 使用HTML5和CSS3实现3D旋转相册效果项目介绍技术栈核心功能实现思路1. HTML结构2. CSS样式解析2.1 基础样式设置2.2 3D效果核心样式2.3 卡片样式 3. JavaScript交互实现3.1 旋转控制3.2 自动播放功能 技术要点总结项目亮点总…

游戏引擎学习第186天

回顾并规划今天的任务 现在&#xff0c;我们站在了一个关键的时刻&#xff0c;准备突破&#xff0c;拥有一些优秀的性能分析代码。从目前来看&#xff0c;我们已经能够看到时间的消耗情况&#xff0c;我对这一点感到非常兴奋。昨天的直播中我们勉强让一些东西工作了&#xff0…

【redis】持久化之RDB与AOF

在数字世界的脉搏中&#xff0c;数据是流淌的血液&#xff0c;而持久化则是保障系统生命力的核心机制。作为内存数据库的标杆&#xff0c;Redis凭借其高性能特性成为互联网架构的基石&#xff0c;但其「易失性」的天然属性也催生了关键命题&#xff1a;如何在服务重启或故障时保…

Brainstorm绘制功能连接图(matlab)

上篇笔记简单介绍了Brainstorm&#xff0c;本次使用Brainstorm绘制功能连接图。而对于连接矩阵&#xff0c;软件中有几种方法&#xff1a;相关、相干、双变量格兰杰因果关系、相位锁相值、包络相关、相位转移熵。 首先&#xff0c;对数据进行预处理&#xff0c;保存为.set&…

华为HG532路由器RCE漏洞 CVE-2017-17215 复现

华为HG532路由器RCE漏洞 CVE-2017-17215 CVE-Description Huawei HG532 with some customized versions has a remote code execution vulnerability. An authenticated attacker could send malicious packets to port 37215 to launch attacks. Successful exploit could l…