0

0

Libcurl使用_libcurl跨平台网络传输库应用教程

畫卷琴夢

畫卷琴夢

发布时间:2026-01-13 16:36:16

|

244人浏览过

|

来源于php中文网

原创

libcurl 是底层网络引擎,需手动管理资源;curl_easy_init() 必须配对 curl_easy_cleanup() 防泄漏;POST 数据超2GB时 CURLOPT_POSTFIELDS 失效;SSL 支持需先确认。

libcurl使用_libcurl跨平台网络传输库应用教程

libcurl 不是开箱即用的“应用框架”,它是一个 C 语言编写的底层网络传输引擎,直接调用 libcurl 需要手动管理句柄、回调、错误和内存——没封装就别想写得快。

curl_easy_init() 后必须配对 curl_easy_cleanup()

这是最常被忽略的资源泄漏源头。每次 curl_easy_init() 返回一个 CURL* 句柄,它内部持有 DNS 缓存、SSL 上下文、连接池等资源。不调用 curl_easy_cleanup() 就退出,会导致:

  • Linux/macOS 下 socket 文件描述符泄露,跑几次就 hit Too many open files
  • Windows 下 HANDLE 泄漏,进程句柄数飙升
  • SSL 证书缓存无法释放,重复请求可能复用过期会话

即使只发一次请求,也要写成:

struct curl_slist *headers = NULL;
CURL *curl = curl_easy_init();
if (curl) {
  curl_easy_setopt(curl, CURLOPT_URL, "https://httpbin.org/get");
  curl_easy_setopt(curl, CURLOPT_HTTPHEADER, headers);
  curl_easy_perform(curl);
  curl_easy_cleanup(curl); // 必须有
}
curl_slist_free_all(headers); // 同样不能漏

POST 数据体大小超过 2GB 时 CURLOPT_POSTFIELDS 失效

CURLOPT_POSTFIELDS 接收 void*size_t,但某些旧版 libcurl(long 截断长度,导致超大 body 被截断或触发断言失败。

安全做法是改用 CURLOPT_READFUNCTION 流式上传:

size_t read_callback(void *ptr, size_t size, size_t nmemb, void *userp) {
  FILE *fp = (FILE*)userp;
  size_t len = fread(ptr, size, nmemb, fp);
  if (len == 0 && feof(fp)) return 0;
  return len;
}

// 使用时:
FILE *fp = fopen("bigfile.bin", "rb");
curl_easy_setopt(curl, CURLOPT_UPLOAD, 1L);
curl_easy_setopt(curl, CURLOPT_READFUNCTION, read_callback);
curl_easy_setopt(curl, CURLOPT_READDATA, fp);
curl_easy_setopt(curl, CURLOPT_INFILESIZE_LARGE, (curl_off_t)file_size);
  • CURLOPT_INFILESIZE_LARGE 必须设为 curl_off_t 类型,不能用 CURLOPT_INFILESIZE
  • fread 返回值需原样返回,libcurl 不做二次校验
  • 文件指针 fp 生命周期必须覆盖整个传输过程

多线程环境下 CURLOPT_NOSIGNAL 必须设为 1L

libcurl 默认启用 alarm()siglongjmp() 实现超时控制,在多线程程序中(尤其是使用 glibc 的 Linux),这会干扰主线程信号处理,引发随机 crash 或 hang。

无界AI
无界AI

一站式AI创作、搜索、分享服务

下载

正确做法是在每个 CURL* 句柄上显式禁用:

curl_easy_setopt(curl, CURLOPT_NOSIGNAL, 1L);
  • 该选项不影响超时功能本身,libcurl 会退回到 select()/poll() 轮询实现
  • 若同时用 curl_multi_* 接口,还需确保所有线程共享的 CURLM* 句柄也满足此要求(multi 接口默认已规避 signal)
  • macOS 上虽不报错,但 siglongjmp 可能破坏 Objective-C ARC 帧,导致野指针

SSL 证书验证失败时 CURLOPT_SSL_VERIFYPEER=0L 不是解法

关掉证书验证(CURLOPT_SSL_VERIFYPEER, 0L)只是掩盖问题,且会让中间人攻击畅通无阻。真实场景应:

  • CURLOPT_CAINFO 指向系统可信根证书路径(如 Linux 的 /etc/ssl/certs/ca-bundle.crt
  • 或用 CURLOPT_CAPATH 指向目录(需先用 c_rehash 建索引)
  • 若服务端用私有 CA,把对应 PEM 文件路径传给 CURLOPT_CAINFO

调试阶段可加 CURLOPT_VERBOSE, 1L 查看握手细节,常见失败原因包括:

  • 服务器证书域名不匹配(CN 或 SAN 不含请求 Host)
  • 证书链不全(Nginx/Apache 未配置 fullchain.pem)
  • 系统时间错误(证书有效期校验失败)

跨平台打包时,别硬编码证书路径;用 curl_version_info(CURLVERSION_NOW)->features & CURL_VERSION_SSL 先确认 SSL 支持可用,再决定是否加载证书。

相关专题

更多
nginx 重启
nginx 重启

nginx重启对于网站的运维来说是非常重要的,根据不同的需求,可以选择简单重启、平滑重启或定时重启等方式。本专题为大家提供nginx重启的相关的文章、下载、课程内容,供大家免费下载体验。

229

2023.07.27

nginx 配置详解
nginx 配置详解

Nginx的配置是指设置和调整Nginx服务器的行为和功能的过程。通过配置文件,可以定义虚拟主机、HTTP请求处理、反向代理、缓存和负载均衡等功能。Nginx的配置语法简洁而强大,允许管理员根据自己的需要进行灵活的调整。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

496

2023.08.04

nginx配置详解
nginx配置详解

NGINX与其他服务类似,因为它具有以特定格式编写的基于文本的配置文件。本专题为大家提供nginx配置相关的文章,大家可以免费学习。

498

2023.08.04

tomcat和nginx有哪些区别
tomcat和nginx有哪些区别

tomcat和nginx的区别:1、应用领域;2、性能;3、功能;4、配置;5、安全性;6、扩展性;7、部署复杂性;8、社区支持;9、成本;10、日志管理。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

227

2024.02.23

nginx报404怎么解决
nginx报404怎么解决

当访问 nginx 网页服务器时遇到 404 错误,表明服务器无法找到请求资源,可以通过以下步骤解决:1. 检查文件是否存在且路径正确;2. 检查文件权限并更改为 644 或 755;3. 检查 nginx 配置,确保根目录设置正确、没有冲突配置等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

333

2024.07.09

Nginx报404错误解决方法
Nginx报404错误解决方法

解决方法:只需要加上这段配置:try_files $uri $uri/ /index.html;即可。想了解更多Nginx的相关内容,可以阅读本专题下面的文章。

3507

2024.08.07

nginx部署php项目教程汇总
nginx部署php项目教程汇总

本专题整合了nginx部署php项目教程汇总,阅读专题下面的文章了解更多详细内容。

5

2026.01.13

nginx配置文件详细教程
nginx配置文件详细教程

本专题整合了nginx配置文件相关教程详细汇总,阅读专题下面的文章了解更多详细内容。

3

2026.01.13

php与html混编教程大全
php与html混编教程大全

本专题整合了php和html混编相关教程,阅读专题下面的文章了解更多详细内容。

0

2026.01.13

热门下载

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

精品课程

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

共48课时 | 7.1万人学习

Git 教程
Git 教程

共21课时 | 2.6万人学习

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

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