0

0

Libcurl C++例子_C++使用libcurl库的完整示例代码

幻夢星雲

幻夢星雲

发布时间:2026-01-08 13:09:31

|

448人浏览过

|

来源于php中文网

原创

必须检查 curl_easy_init() 返回值是否为 nullptr,否则未检查时调用 curl_easy_setopt() 会因空指针导致段错误;设置 URL 前须确保以 http:// 或 https:// 开头;HTTPS 需链接 OpenSSL/mbedtls;WRITEFUNCTION 回调签名必须严格匹配;curl_easy_cleanup 必须成对调用且不可重复;多线程需独立句柄。

libcurl c++例子_c++使用libcurl库的完整示例代码

curl_easy_init 之后必须检查返回值是否为 nullptr

libcurl 的初始化函数 curl_easy_init() 在内存不足或内部初始化失败时会返回 nullptr,但很多示例代码直接假设它一定成功。C++ 程序中若未检查就调用 curl_easy_setopt(),会导致段错误(SIGSEGV)。

  • 永远在 curl_easy_init() 后加 if (!curl) { /* error */ } 判断
  • 常见触发场景:容器环境内存受限、嵌入式设备资源紧张、LD_PRELOAD 干扰
  • 不检查的后果不是报错信息,而是直接 crash,调试时容易误判为网络层问题

设置 CURLOPT_URL 和 CURLOPT_FOLLOWLOCATION 前必须确保 URL 以 http:// 或 https:// 开头

libcurl 对协议前缀敏感,CURLOPT_URL 若传入 "example.com""//cdn.example.com/file" 会被视为非法 URL,curl_easy_perform() 返回 CURLE_URL_MALFORMAT(错误码 3)。

  • 正确写法:curl_easy_setopt(curl, CURLOPT_URL, "https://www.php.cn/link/4d2fe2e8601f7a8018594d98f28706f2");
  • CURLOPT_FOLLOWLOCATION 默认关闭,重定向(301/302)不会自动跳转;开启后需注意 CURLOPT_MAXREDIRS 防止环形重定向
  • HTTPS 请求必须链接 OpenSSL 或 mbedtls,否则运行时报 CURLE_UNSUPPORTED_PROTOCOL(错误码 1

使用 CURLOPT_WRITEFUNCTION 时,回调函数签名和返回值必须严格匹配

C++ 中若用 lambda 或普通函数做回调,容易因签名不符导致未定义行为——尤其是返回值类型错误时,libcurl 可能截断响应或提前终止传输。

  • 合法签名必须是:size_t function(void *ptr, size_t size, size_t nmemb, void *userdata)
  • 返回值应为实际处理的字节数:return size * nmemb;,不能返回 0(除非主动中止)或大于该值
  • 常见错误:用 intvoid 做返回类型;在类成员函数中忽略 static 修饰(导致隐式 this 参数)
extern "C" size_t WriteCallback(void* contents, size_t size, size_t nmemb, void* userp) {
  size_t realsize = size * nmemb;
  std::string* mem = static_cast(userp);
  mem->append(static_cast(contents), realsize);
  return realsize;
}

int main() { CURL* curl = curl_easy_init(); if (!curl) return -1;

std::string response; curl_easy_setopt(curl, CURLOPT_URL, "https://www.php.cn/link/4d2fe2e8601f7a8018594d98f28706f2"); curl_easy_setopt(curl, CURLOPT_WRITEFUNCTION, WriteCallback); curl_easy_setopt(curl, CURLOPT_WRITEDATA, &response); curl_easy_setopt(curl, CURLOPT_FOLLOWLOCATION, 1L); CURLcode res = curl_easy_perform(curl);

if (res != CURLE_OK) { fprintf(stderr, "curl_easy_perform() failed: %s\n", curl_easy_strerror(res)); } else { printf("Response length: %zu\n", response.length()); }

curl_easy_cleanup(curl); return 0; }

curl_easy_cleanup 必须在每次 curl_easy_init 之后调用,且不能重复调用

libcurl 内部维护连接池、SSL 上下文、DNS 缓存等资源。curl_easy_cleanup() 是唯一释放这些资源的入口。漏掉会导致内存泄漏;重复调用(如异常路径未 guard)会引发 double-free 或崩溃。

企业网站在线超市131014
企业网站在线超市131014

这是一个在线展示企业网站范例的源代码,涉及36个行业分类近500个精美企业网站程序范例——不论是对美工还是程序员,都有相当高的参考价值! 使用 后台管理:登录用户为“admin”,登录密码为“admin888”,登录页面为“Manage.asp”。 包含“管理员管理/添加网站/管理网站/数据库和上传文件管理”的完整功能。 其他 请把数据库后缀名MDB改为ASP防下载,同时修改两个Conn.asp

下载

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

  • 推荐用 RAII 封装:构造时 curl_easy_init(),析构时 curl_easy_cleanup()
  • 多线程环境下,每个线程应持有独立 CURL* 句柄,不可共享
  • 若使用 curl_global_init(CURL_GLOBAL_DEFAULT),程序退出前需配对调用 curl_global_cleanup(),否则 Valgrind 会报告全局内存泄漏

libcurl 的坑不在语法复杂,而在“看起来能跑通,但边界条件下悄无声息地失败”。比如 URL 缺协议、回调返回值错一位、cleanup 漏掉一次——这些都不会编译报错,却让程序在特定服务器、特定网络路径或压力测试时突然崩掉。

相关专题

更多
if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

723

2023.08.22

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

scripterror怎么解决
scripterror怎么解决

scripterror的解决办法有检查语法、文件路径、检查网络连接、浏览器兼容性、使用try-catch语句、使用开发者工具进行调试、更新浏览器和JavaScript库或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

186

2023.10.18

500error怎么解决
500error怎么解决

500error的解决办法有检查服务器日志、检查代码、检查服务器配置、更新软件版本、重新启动服务、调试代码和寻求帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

271

2023.10.25

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

315

2023.08.02

int占多少字节
int占多少字节

int占4个字节,意味着一个int变量可以存储范围在-2,147,483,648到2,147,483,647之间的整数值,在某些情况下也可能是2个字节或8个字节,int是一种常用的数据类型,用于表示整数,需要根据具体情况选择合适的数据类型,以确保程序的正确性和性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

529

2024.08.29

c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

50

2025.08.29

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

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

27

2026.01.09

热门下载

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

精品课程

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

共578课时 | 43.7万人学习

国外Web开发全栈课程全集
国外Web开发全栈课程全集

共12课时 | 1.0万人学习

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

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