0

0

c++ Libcurl怎么用 c++发送HTTP请求教程【实例】

冰火之心

冰火之心

发布时间:2026-01-04 16:09:10

|

780人浏览过

|

来源于php中文网

原创

C++调用libcurl发送HTTP请求需初始化句柄、设置选项、执行请求、处理响应并清理资源;其为C风格API,稳定适合生产环境,支持GET/POST及状态码获取。

c++ libcurl怎么用 c++发送http请求教程【实例】

用 C++ 调用 libcurl 发送 HTTP 请求,核心是初始化 curl 句柄、设置选项、执行请求、处理响应、清理资源。它不是开箱即用的“类库”,而是 C 风格 API,但封装得清晰稳定,适合生产环境。

1. 安装与基础配置

Linux(如 Ubuntu)直接安装开发包:

sudo apt install libcurl4-openssl-dev

macOS 用 Homebrew:

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

brew install curl

Windows 推荐用 vcpkg:
vcpkg install curl:x64-windows
然后在 CMakeLists.txt 中链接 curl 库,并确保包含头文件路径。

代码开头必须包含:

#include

DeepAI
DeepAI

为天生具有创造力的人提供的AI工具

下载

2. GET 请求(带超时和错误检查)

这是最常用场景。关键点:必须设置 CURLOPT_URLCURLOPT_FOLLOWLOCATION(重定向)、CURLOPT_TIMEOUT(防卡死),并提供回调函数接收响应体。

示例代码片段:

static size_t WriteCallback(void* contents, size_t size, size_t nmemb, void* userp) {
    size_t realsize = size * nmemb;
    std::string* buf = static_cast(userp);
    buf->append(static_cast(contents), realsize);
    return realsize;
}

std::string httpGet(const std::string& url) { CURL* curl; CURLcode res; std::string response;

curl = curl_easy_init();
if (!curl) return "";

curl_easy_setopt(curl, CURLOPT_URL, url.c_str());
curl_easy_setopt(curl, CURLOPT_WRITEFUNCTION, WriteCallback);
curl_easy_setopt(curl, CURLOPT_WRITEDATA, &response);
curl_easy_setopt(curl, CURLOPT_FOLLOWLOCATION, 1L);
curl_easy_setopt(curl, CURLOPT_TIMEOUT, 10L);
curl_easy_setopt(curl, CURLOPT_USERAGENT, "cpp-libcurl/1.0");

res = curl_easy_perform(curl);
if (res != CURLE_OK) {
    fprintf(stderr, "curl_easy_perform() failed: %s\n", curl_easy_strerror(res));
}

curl_easy_cleanup(curl);
return response;

}

3. POST 请求(JSON 数据)

发送 JSON 时需手动设置 Content-Type 头,并把 JSON 字符串作为 POST body。注意:libcurl 默认不自动识别 JSON,必须显式设置头和数据指针。

  • CURLOPT_POSTFIELDS 传原始字符串(适合小数据)
  • CURLOPT_POST 启用 POST 方法(或更推荐 CURLOPT_CUSTOMREQUEST + CURLOPT_POSTFIELDS 组合)
  • CURLOPT_HTTPHEADER 添加自定义 header(如 application/json)

示例:

std::string httpPostJson(const std::string& url, const std::string& json) {
    CURL* curl;
    CURLcode res;
    std::string response;
curl = curl_easy_init();
if (!curl) return "";

struct curl_slist* headers = nullptr;
headers = curl_slist_append(headers, "Content-Type: application/json");

curl_easy_setopt(curl, CURLOPT_URL, url.c_str());
curl_easy_setopt(curl, CURLOPT_POST, 1L);
curl_easy_setopt(curl, CURLOPT_POSTFIELDS, json.c_str());
curl_easy_setopt(curl, CURLOPT_POSTFIELDSIZE, json.length());
curl_easy_setopt(curl, CURLOPT_HTTPHEADER, headers);
curl_easy_setopt(curl, CURLOPT_WRITEFUNCTION, WriteCallback);
curl_easy_setopt(curl, CURLOPT_WRITEDATA, &response);
curl_easy_setopt(curl, CURLOPT_TIMEOUT, 10L);

res = curl_easy_perform(curl);
if (res != CURLE_OK) {
    fprintf(stderr, "POST failed: %s\n", curl_easy_strerror(res));
}

curl_slist_free_all(headers);
curl_easy_cleanup(curl);
return response;

}

4. 处理状态码与常见错误

仅靠 curl_easy_perform() 返回值不够——它只表示网络层是否成功(如 DNS 解析、连接、发送)。要获取 HTTP 状态码(如 404、500),必须调用 curl_easy_getinfo()

long http_code = 0;
curl_easy_getinfo(curl, CURLINFO_RESPONSE_CODE, &http_code);
if (http_code == 200) {
    // 成功
} else if (http_code >= 400) {
    // 客户端或服务端错误
}

常见失败原因:

  • CURLE_COULDNT_RESOLVE_HOST:域名解析失败 → 检查网络或 DNS
  • CURLE_COULDNT_CONNECT:无法建立 TCP 连接 → 检查目标地址、端口防火墙
  • CURLE_OPERATION_TIMEDOUT:超时 → 调大 CURLOPT_TIMEOUT 或检查服务可用性
  • 返回空响应但无报错 → 很可能是未设置 CURLOPT_FOLLOWLOCATION 导致 302 重定向被忽略

不复杂但容易忽略。

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

406

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

531

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

309

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

74

2025.09.10

curl_exec
curl_exec

curl_exec函数是PHP cURL函数列表中的一种,它的功能是执行一个cURL会话。给大家总结了一下php curl_exec函数的一些用法实例,这个函数应该在初始化一个cURL会话并且全部的选项都被设置后被调用。他的返回值成功时返回TRUE, 或者在失败时返回FALSE。

425

2023.06.14

linux常见下载安装工具
linux常见下载安装工具

linux常见下载安装工具有APT、YUM、DNF、Snapcraft、Flatpak、AppImage、Wget、Curl等。想了解更多linux常见下载安装工具相关内容,可以阅读本专题下面的文章。

174

2023.10.30

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

253

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

206

2023.09.04

Golang 分布式缓存与高可用架构
Golang 分布式缓存与高可用架构

本专题系统讲解 Golang 在分布式缓存与高可用系统中的应用,涵盖缓存设计原理、Redis/Etcd集成、数据一致性与过期策略、分布式锁、缓存穿透/雪崩/击穿解决方案,以及高可用架构设计。通过实战案例,帮助开发者掌握 如何使用 Go 构建稳定、高性能的分布式缓存系统,提升大型系统的响应速度与可靠性。

59

2026.01.09

热门下载

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

精品课程

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

共48课时 | 6.8万人学习

Git 教程
Git 教程

共21课时 | 2.5万人学习

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

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