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 概述(翻译)的更多相关文章

  1. HugePages概述--翻译自19C文档

    翻译自: https://docs.oracle.com/en/database/oracle/oracle-database/19/unxar/administering-oracle-databa ...

  2. docker-compose概述--翻译

    Overview of Docker Compose 译文 Docker Compose 是一个用来定义和执行多Docker容器程序的工具,如果使用Compose,你将可以使用一个YAML文件来配置你 ...

  3. [翻译]开发文档:android Bitmap的高效使用

    内容概述 本文内容来自开发文档"Traning > Displaying Bitmaps Efficiently",包括大尺寸Bitmap的高效加载,图片的异步加载和数据缓存 ...

  4. 翻译qmake文档 目录

    利用空闲时间把qmke的文档翻译出来,翻译水平有限,有些地方翻译的不好,请谅解, 如果您能指出来,我会很感激并在第一时候做出修改. 翻译qmake文档(一) qmake指南和概述 翻译qmake文档( ...

  5. [翻译]Bitmap的异步加载和缓存

    内容概述 [翻译]开发文档:android Bitmap的高效使用 本文内容来自开发文档"Traning > Displaying Bitmaps Efficiently", ...

  6. SQL Server中的事务日志管理的阶梯,级别1:事务日志概述

    SQL Server中的事务日志管理的阶梯,级别1:事务日志概述 翻译:刘琼滨 谢雪妮 许雅莉 赖慧芳 级别1:事务日志概述 事务日志是一个文件,其中SQL服务器存储了所有与日志文件关联的数据库执行的 ...

  7. Unity3D用户手册

    Unity Manual 用户手册 Welcome to Unity. 欢迎使用Unity. Unity is made to empower users to create the best int ...

  8. 翻译qmake文档(一) qmake指南和概述

    翻译qmake文档 目录 英文文档连接: http://qt-project.org/doc/qt-5/qmake-manual.html http://qt-project.org/doc/qt-5 ...

  9. Apache log4net™ 手册——概述【翻译】

    原文地址 本文内容 概述 框架 日志(Loggers)和追加器(Appenders) 日志层次(Logger hierarchy) 追加器(Appenders) 筛选(Filters) 布局(Layo ...

随机推荐

  1. JVM 基础面试题总结

    hey guys, 各位小伙伴们大家好,这里是程序员cxuan,欢迎你收看我新一期的文章,这篇文章我花了几天时间给你汇总了一波 JVM 的基础知识和面试题,内容还不是很全,我还在连载中,这篇文章相当于 ...

  2. asp.net core 搭建WebAPI微服务-----cosnul服务

    参考网址:https://blog.csdn.net/weixin_42084199/article/details/108643555 在此之前需要准备的是: vs2019,以往版本不支持dotne ...

  3. C++11 weak_ptr智能指针

    和 shared_ptr.unique_ptr 类型指针一样,weak_ptr 智能指针也是以模板类的方式实现的.weak_ptr<T>( T 为指针所指数据的类型)定义在<memo ...

  4. C# 单元测试,测试资源管理器里面没有需要的单元测试

    已经创建了单元测试,却无法运行,更改引用的程序集,将TestPlatform换位QualityTools.UnitTestFramework.具体原因尚未分析,随笔记录.

  5. 【ArcEngine】多用户同时编辑同一个版本数据的解决方法

    ArcMap或ArcEngine中,使用多个用户同时编辑default版本的时候,问题就来了,StopEditing 错误信息如下 FDO_E_VERSION_REDEFINED -214721714 ...

  6. c# button Command

    internal class DelegateCommand : ICommand { private readonly Action _execute; private readonly Func& ...

  7. JDBC中级篇(MYSQL)——模拟从数据库中上传下载附件

    注意:其中的JdbcUtil是我自定义的连接工具类:代码例子链接: package b_blob_clob; import java.io.BufferedOutputStream; import j ...

  8. 阿里云服务器上部署java项目(安装jdk,tomcat)

    安装JDK a.执行下面的yum指令安装,无线配置环境变量. 1.yum -y update #首先更新一下YUM源2.yum list Java* ---------#列出所有的JDK 3.yum ...

  9. k8s笔记0528-基于KUBERNETES构建企业容器云手动部署集群记录-2

    三.ETCD集群部署 类似于走zookeeper集群分布式协调服务,可做以key v形式存储在ETCD中. 官方链接:https://github.com/coreos/etcd 分布式kv存储,为分 ...

  10. linux centos7 重启后网络出现问题

    2021-08-04 重启虚拟机后发现网络出了问题,输入 ip a 查看网络,出现以下情况 查看配置文件 cat /etc/sysconfig/network-scripts/ifcfg-ens33  ...