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 ...
随机推荐
- 接入华为应用内支付,验证购买Token接口,返回“rights invalid”
有海外开发者向我们提问:我在应用中集成了华为应用内支付SDK(测试购买订阅型商品),按照文档说明,在服务器去请求验证购买Token接口的时候返回了{"responseCode":& ...
- NOIP 模拟 $19\; \rm v$
题解 一道概率与期望的状压题目 这种最优性的题目,我们一般都是倒着转移,因为它的选择是随机的所以我们无法判断从左还是从右更有,所以我们都搜一遍 时间一定会爆,采用记忆化搜索,一种状态的答案一定是固定的 ...
- vue路由history模式,nginx配置
nginx配置内容 # For more information on configuration, see: # * Official English Documentation: http://n ...
- C#与.NET、CLR、CLI是什么关系?什么是.NET框架
1.C#与.NET.CLR.CLI是什么关系?什么是.NET框架? 这个问题好专业啊!一句话两句话还真不好说清.您听说过C++中有个COM的概念吧?您听说过JAVA里的虚拟机吧?CLR(公共 ...
- uwp 动画之圆的放大与缩小
xml code --------------------------------------------------- <Page x:Class="MyApp.MainPage&q ...
- WPF---数据模板(一)
一.场景模拟 假设我们现在有如下需求: 我们需要在ListBox中的每个Item中显示某个成员的姓名.年龄以及喜欢的颜色,点击Item的时候,会在右边显示详细信息,同时也想让ListBox的样式变得好 ...
- Git修改历史commit的author信息
前言 "嘀嗒嘀嗒",抬头看向墙上的钟表,此时已是凌晨1点.小明终于把Go语言圣经第二章的笔记写完,保存commit,提交,然后睡觉. 额,等等,不对,小明发现他用的是公司的git账 ...
- Layui form表单提交注意事项
// 表单提交form.on('submit(first1)', function (data) { var articleFrom = data.field; $.ajax({ type:" ...
- Ubuntu 16.04LTS下eclipse连接mysql
第一部分:打开eclipse,新建一个web工程,新建一个类db_test.java(jdbc连接mysql的原理自行百度) import java.sql.*; public class db_te ...
- 笔记本+ubuntu18.04 关闭触摸板touchpad
方法1: Settings -> Devices -> Mouse&Touchpad -> Touchpad OFF 方法2: 终端运行如下命令 touchpad off: ...