0

0

C++如何实现简单的FTP文件上传_C++使用libcurl操作网络文件【实战】

冰火之心

冰火之心

发布时间:2026-02-06 12:47:02

|

594人浏览过

|

来源于php中文网

原创

必须启用被动模式(PASV)才能在现代网络中成功上传,关键选项包括CURLOPT_URL(含凭据)、CURLOPT_UPLOAD、CURLOPT_READDATA、CURLOPT_FTP_USE_PASV=1L;禁用EPSV可提升兼容性;错误处理需关注CURLE_LOGIN_DENIED、CURLE_REMOTE_FILE_NOT_FOUND等码;大文件须流式读取并设CURLOPT_INFILESIZE_LARGE和超时参数;FTP上传不可用HTTP相关选项。

c++如何实现简单的ftp文件上传_c++使用libcurl操作网络文件【实战】

如何用 libcurl 在 C++ 中上传文件到 FTP 服务器

libcurl 支持 FTP 上传,但默认是主动模式(PORT),很多现代网络环境(如 NAT、防火墙)会阻断数据连接。必须显式启用被动模式(PASV),否则 CURLE_COULDNT_CONNECT 或超时是大概率事件。

关键不是“能不能传”,而是“怎么让连接通”。上传本身只需设置几个选项,难点在连接建立阶段。

  • curl_easy_setopt(curl, CURLOPT_URL, "ftp://user:pass@host/path/file.txt") —— URL 必须含完整凭据和目标路径,不能只写域名
  • curl_easy_setopt(curl, CURLOPT_UPLOAD, 1L) —— 启用上传模式(不是 POST)
  • curl_easy_setopt(curl, CURLOPT_READDATA, &file_handle) —— 绑定已打开的 FILE*,libcurl 会从中读取内容
  • curl_easy_setopt(curl, CURLOPT_FTP_USE_EPSV, 0L) —— 强制禁用 EPSV(IPv6 扩展 PASV),避免某些老 FTP 服务器不兼容
  • curl_easy_setopt(curl, CURLOPT_FTP_USE_PASV, 1L) —— 必开,否则大概率连不上数据通道

处理 FTP 上传中的常见错误码

上传失败时,curl_easy_perform() 返回非零值,需结合 curl_easy_strerror() 和 HTTP/FTP 状态码判断原因。最常遇到的不是认证失败,而是路径或权限问题。

  • CURLE_LOGIN_DENIED:用户名/密码错,或服务器拒绝该用户 FTP 登录(注意:有些服务器关闭 FTP 账号,只留 SFTP)
  • CURLE_REMOTE_FILE_NOT_FOUND:目标目录不存在,libcurl 不自动创建父目录,需提前用 ftp://.../path/ + CURLOPT_CUSTOMREQUEST "MKD path" 手动建
  • CURLE_FTP_COULDNT_STOR_FILE:权限不足(如目标目录不可写)、磁盘满、或文件名含非法字符(空格、中文未编码
  • CURLE_OPERATION_TIMEDOUT:90% 是 PASV 模式被防火墙拦截,检查是否设置了 CURLOPT_FTP_USE_PASV

上传大文件时如何避免内存暴涨和超时

libcurl 默认会把整个文件读入缓冲区再发,对大文件极不友好。必须配合流式读取 + 合理超时控制,否则程序卡死或被服务器断连。

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

情感家园企业站5.0 多语言多风格版
情感家园企业站5.0 多语言多风格版

一套面向小企业用户的企业网站程序!功能简单,操作简单。实现了小企业网站的很多实用的功能,如文章新闻模块、图片展示、产品列表以及小型的下载功能,还同时增加了邮件订阅等相应模块。公告,友情链接等这些通用功能本程序也同样都集成了!同时本程序引入了模块功能,只要在系统默认模板上创建模块,可以在任何一个语言环境(或任意风格)的适当位置进行使用!

下载
  • fopen(..., "rb") 打开文件,传给 CURLOPT_READDATA,libcurl 内部按需调用 fread()
  • curl_easy_setopt(curl, CURLOPT_INFILESIZE_LARGE, (curl_off_t)file_size) —— 显式告知大小,避免 libcurl 自己 fseek(SEEK_END)(某些文件系统不支持)
  • curl_easy_setopt(curl, CURLOPT_TIMEOUT, 300L) —— 总超时设长些;CURLOPT_LOW_SPEED_LIMITCURLOPT_LOW_SPEED_TIME 可防慢速挂起
  • 不要用 std::stringstd::vector 全局加载文件——这是新手最常踩的内存坑

为什么 CURLOPT_POST 和 CURLOPT_HTTPPOST 不能用于 FTP 上传

因为 FTP 不是 HTTP 协议。CURLOPT_POST 仅对 HTTP/HTTPS 有效,强行设了也无作用;CURLOPT_HTTPPOST 是 multipart/form-data 专用,和 FTP 完全无关。混淆这两者会导致静默失败——curl 返回 CURLE_OK,但服务器根本没收到文件。

FTP 上传唯一正路是 CURLOPT_UPLOAD + CURLOPT_READDATA。如果看到示例混用 HTTP 选项,基本可以判定它跑不通 FTP。

另外注意:libcurl 的 FTP 支持默认编译进库,但如果你用的是精简版(比如 Android NDK 自带的 curl),可能不含 FTP 协议,此时 curl_version_info(CURLVERSION_NOW)->features & CURL_VERSION_FTP 会返回 0,得换全量库。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
string转int
string转int

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

606

2023.08.02

curl_exec
curl_exec

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

445

2023.06.14

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

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

179

2023.10.30

android开发三大框架
android开发三大框架

android开发三大框架是XUtil框架、volley框架、ImageLoader框架。本专题为大家提供android开发三大框架相关的各种文章、以及下载和课程。

301

2023.08.14

android是什么系统
android是什么系统

Android是一种功能强大、灵活可定制、应用丰富、多任务处理能力强、兼容性好、网络连接能力强的操作系统。本专题为大家提供android相关的文章、下载、课程内容,供大家免费下载体验。

1759

2023.08.22

android权限限制怎么解开
android权限限制怎么解开

android权限限制可以使用Root权限、第三方权限管理应用程序、ADB命令和Xposed框架解开。详细介绍:1、Root权限,通过获取Root权限,用户可以解锁所有权限,并对系统进行自定义和修改;2、第三方权限管理应用程序,用户可以轻松地控制和管理应用程序的权限;3、ADB命令,用户可以在设备上执行各种操作,包括解锁权限;4、Xposed框架,用户可以在不修改系统文件的情况下修改应用程序的行为和权限。

2058

2023.09.19

android重启应用的方法有哪些
android重启应用的方法有哪些

android重启应用有通过Intent、PendingIntent、系统服务、Runtime等方法。本专题为大家提供Android相关的文章、下载、课程内容,供大家免费下载体验。

277

2023.10.18

Android语音播放功能实现方法
Android语音播放功能实现方法

实现方法有使用MediaPlayer实现、使用SoundPool实现两种。可以根据具体的需求选择适合的方法进行实现。想了解更多语音播放的相关内容,可以阅读本专题下面的文章。

352

2024.03.01

Golang处理数据库错误教程合集
Golang处理数据库错误教程合集

本专题整合了Golang数据库错误处理方法、技巧、管理策略相关内容,阅读专题下面的文章了解更多详细内容。

2

2026.02.06

热门下载

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

精品课程

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

共162课时 | 15.9万人学习

Java 教程
Java 教程

共578课时 | 59万人学习

Uniapp从零开始实现新闻资讯应用
Uniapp从零开始实现新闻资讯应用

共64课时 | 6.8万人学习

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

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