libcurl 概述(翻译)
l名称
libcurl 客户端 URL 传输
描述
这是一个如何使用libcurl进行C语言编程的简短概述。这里提到的每个功能都有特定的手册页。还有 libcurl-easy 手册页,libcurl-multi 手册页,libcurl-share 手册页和libcurl_tutorial 手册页,用于深入理解如何使用libcurl进行编程。
有很多可用的绑定让你可以使用喜欢的语言访问libcurl,在其它地方寻找这些文档。
libcurl有一个全局环境常量,使用libcurl时必须手动设置和维护。换句话说你需要在你的程序开始之前调用 curl_global_init,程序结束之后调用 curl_global_cleanup。详细描述参考 GLOBAL CONSTANTS。
如果编译的 libcurl 支持 SSL backends,调用 curl_global_init 前可调用 curl_global_sslset 来选择活动 SSL backend。
要传输文件,你可以使用 curl_easy_init 创建一个简单句柄(easy handle)用于单个传输(在任一方向)。然后使用 curl_easy_setopt 在该句柄中设置所需的选项集。使用 curl_easy_setopt 设置的选项,将在每次重复使用此句柄时生效,直到您更改选项,或者使用 curl_easy_reset 重置它们。
要真正的传输数据,你可以选择使用简单接口(easy interface)或多接口(multi interface)。
简单接口是一个同步接口,使用该接口时调用 curl_easy_perform 来执行传输工作。当传输完成时,函数返回并继续后续流程。更多详细信息参考 libcurl-easy 手册页。
多接口是一个异步接口,使用该接口时调用 curl_multi_perform 来执行传输工作。每次调用时只执行一小部分传输。如果在传输的过程中可以做其它事情,那就完美了。多接口允许您在 libcurl 上执行 select 操作,甚至可以使用单线程轻松地同时下载多个文件。更多详细信息参考 libcurl-multi 手册页。
你可以实现多个简单接口共享某些数据,甚至它们使用在多个不同的线程中。这个神奇的功能是由共享接口(share interface)实现的,详细信息参考 libcurl-share 手册页。
还有一系列其它有用的功能可供使用,包括:
- curl_version_info()
- 获取详细的libcurl(和其它使用的库)版本信息
- curl_getdate()
- 将日期字符串转换为time_t
- curl_easy_getinfo()
- 获取已执行传输的信息
- curl_formadd()
- 帮助构建HTTP表单POST
- curl_formfree()
- 释放使用curl_formadd构建的列表
- curl_slist_append()
- 建立一个链表
- curl_slist_free_all();
- 释放整个curl_slist
与 LIBCURL 联系
在类Unix的机器上,有一个名为 "curl-config" 的工具,当执行 'make install' 时,它会与curl其余的文件一起安装。
附加curl-config使应用程序与libcurl之间的链接以及开发者学习如何使用libcurl变得简单。
运行 'curl-config --libs' 获取你需要的(额外的)连接选项,链接到你已安装libcurl的特定版本。更多详细信息参考 curl-config 手册页。
将libcurl作为其发行版的一部分提供的类Unix操作系统通常不提供curl-config工具,而只是为此目的在公共路径中安装库和头文件。
许多Linux和类似系统使用pkg-config提供有关库的构建和链接选项,libcurl也支持这些选项。
LIBCURL 符号名称
libcurl接口中的所有公共函数都以'curl_'为前缀(带小写c)。您可以在库源代码中找到其他函数,但其他前缀表示函数是私有的,可能会在下一版本中更改,恕不另行通知。
仅使用文档化的函数和功能!
可移植性
libcurl 在它编译和构建的任何平台上的工作方式完全相同。
线程
libcurl是线程安全的,但也有一些例外。有关更多信息,请参阅 libcurl-thread。
持久连接
持久连接意味着如果条件合适,libcurl可以为多次传输重用相同的连接。
libcurl将始终尝试使用持久连接。无论何时使用curl_easy_perform或curl_multi_perform等,libcurl都会尝试使用现有的连接进行传输,如果不存在,它将打开一个新的,可以在下一次调用curl_easy_perform或curl_multi_perform时重复使用。
要允许libcurl充分利用持久连接,您应该尽可能使用相同的句柄传输多个文件。
如果您使用简单接口,并且调用curl_easy_cleanup,则libcurl保存的所有可能打开的连接都将被关闭并被遗忘。
未完待续...
libcurl 概述(翻译)的更多相关文章
- HugePages概述--翻译自19C文档
翻译自: https://docs.oracle.com/en/database/oracle/oracle-database/19/unxar/administering-oracle-databa ...
- docker-compose概述--翻译
Overview of Docker Compose 译文 Docker Compose 是一个用来定义和执行多Docker容器程序的工具,如果使用Compose,你将可以使用一个YAML文件来配置你 ...
- [翻译]开发文档:android Bitmap的高效使用
内容概述 本文内容来自开发文档"Traning > Displaying Bitmaps Efficiently",包括大尺寸Bitmap的高效加载,图片的异步加载和数据缓存 ...
- 翻译qmake文档 目录
利用空闲时间把qmke的文档翻译出来,翻译水平有限,有些地方翻译的不好,请谅解, 如果您能指出来,我会很感激并在第一时候做出修改. 翻译qmake文档(一) qmake指南和概述 翻译qmake文档( ...
- [翻译]Bitmap的异步加载和缓存
内容概述 [翻译]开发文档:android Bitmap的高效使用 本文内容来自开发文档"Traning > Displaying Bitmaps Efficiently", ...
- SQL Server中的事务日志管理的阶梯,级别1:事务日志概述
SQL Server中的事务日志管理的阶梯,级别1:事务日志概述 翻译:刘琼滨 谢雪妮 许雅莉 赖慧芳 级别1:事务日志概述 事务日志是一个文件,其中SQL服务器存储了所有与日志文件关联的数据库执行的 ...
- Unity3D用户手册
Unity Manual 用户手册 Welcome to Unity. 欢迎使用Unity. Unity is made to empower users to create the best int ...
- 翻译qmake文档(一) qmake指南和概述
翻译qmake文档 目录 英文文档连接: http://qt-project.org/doc/qt-5/qmake-manual.html http://qt-project.org/doc/qt-5 ...
- Apache log4net™ 手册——概述【翻译】
原文地址 本文内容 概述 框架 日志(Loggers)和追加器(Appenders) 日志层次(Logger hierarchy) 追加器(Appenders) 筛选(Filters) 布局(Layo ...
随机推荐
- mysql悲观锁和乐观锁
悲观锁 查出来的数据必须是根据索引查出来的,不然锁表. # 语法 select * from table where id = 1 for update; 乐观锁 使用一个标识 cas 比较后替换 如 ...
- 利用maven构建一个spring mvc的helloworld实例
刚开始学习maven和spring mvc,学的云里雾里的 这里提供一个hello world实例,记录自己的学习之路 首先看maven官网的介绍 Apache Maven is a software ...
- Scrapy启动spider出错
python 3.7 里,async变成了关键字,所以报错. 解决方法:1回退python3.6版本. 2找到报错的那个py文件,比如manhole.py,将函数参数async改个名字(比如改成asy ...
- YARN的工作过程
yarn的工作执行流程图 1.用户向YARN中提交应用程序 2.ResourceManager为该应用程序找到一个可用的NodeManager 并分配一个Container,然后在这个Containe ...
- 自研 Pulsar Starter:winfun-pulsar-spring-boot-starter
原文:自研 Pulsar Starter:winfun-pulsar-spring-boot-starter 里程碑 版本 功能点 作者 完成 1.0.0 支持PulsarTemplate发送消息&a ...
- rabbitMq镜像集群
rabbitMq延迟投递的方案 1 把消息记录到数据路,通过定时器进行刷新 2 TTL 加上死信队列 :通过路由把过期的消息同步到死信队列,通过死信队列的消费者进行消费 3
- Redis(二):基本数据类型
基础 # redis默认有16个数据库,数组下标从0开始,默认使用0号库 # 当我们启动服务器并连接客户端之后: set <key> <value> # 向数据库中添加数据用于 ...
- Layui引起的对前端的一次记录
前言 首先会做这次记录,也是因为自己也是第一次去接触这个框架,以前总是听说,并没有去用过.这次出于实习的原因,去学习了一下Layui这个"面向后端开发者的框架".其次,此篇记录仅供 ...
- Hopper Disassembler系列之Sublime Text 3 爆破
https://www.52pojie.cn/thread-793069-1-1.html 当参数少于7个时, 参数从左到右放入寄存器: rdi, rsi, rdx, rcx, r8, r9. 当参数 ...
- Linux命令进阶篇之一
利用file命令查看那文件的类型 cd /etc 这里面的文件 命令:file 语法:file [-bLvz] 文件 解释:-b:显示结果,但是不显示文件名称 -L:直接显示符号链接所指向的文件的类型 ...