94个版本

0.5.0 2018年1月3日
0.4.46 2024年2月12日
0.4.44 2022年7月22日
0.4.43 2022年3月12日
0.1.4 2014年12月29日

#3 in HTTP客户端

Download history 115740/week @ 2024-04-30 116778/week @ 2024-05-07 114666/week @ 2024-05-14 118508/week @ 2024-05-21 126241/week @ 2024-05-28 129732/week @ 2024-06-04 128052/week @ 2024-06-11 123775/week @ 2024-06-18 133347/week @ 2024-06-25 116825/week @ 2024-07-02 121652/week @ 2024-07-09 143436/week @ 2024-07-16 152139/week @ 2024-07-23 143379/week @ 2024-07-30 159451/week @ 2024-08-06 154091/week @ 2024-08-13

636,368 每月下载量
900 个crate中使用了 (直接使用270个)

MIT 许可证

6.5MB
147K SLoC

C 124K SLoC // 0.2% comments M4 9K SLoC // 0.3% comments Rust 6K SLoC // 0.1% comments Perl 3K SLoC // 0.2% comments Visual Studio Solution 2K SLoC Batch 2K SLoC Shell 794 SLoC // 0.4% comments Bitbake 460 SLoC // 0.2% comments Automake 433 SLoC // 0.4% comments

curl-rust

libcurl 的Rust绑定

Latest Version Documentation License Build

快速入门

use std::io::{stdout, Write};

use curl::easy::Easy;

// Print a web page onto stdout
fn main() {
    let mut easy = Easy::new();
    easy.url("https://rust-lang.net.cn/").unwrap();
    easy.write_function(|data| {
        stdout().write_all(data).unwrap();
        Ok(data.len())
    }).unwrap();
    easy.perform().unwrap();

    println!("{}", easy.response_code().unwrap());
}
use curl::easy::Easy;

// Capture output into a local `Vec`.
fn main() {
    let mut dst = Vec::new();
    let mut easy = Easy::new();
    easy.url("https://rust-lang.net.cn/").unwrap();

    let mut transfer = easy.transfer();
    transfer.write_function(|data| {
        dst.extend_from_slice(data);
        Ok(data.len())
    }).unwrap();
    transfer.perform().unwrap();
}

Post / Put请求

Easy 上的 putpost 方法可以配置HTTP请求的方法,然后可以使用 read_function 来指定如何填充数据。此接口与实现 Read 的类型配合得很好。

use std::io::Read;
use curl::easy::Easy;

fn main() {
    let mut data = "this is the body".as_bytes();

    let mut easy = Easy::new();
    easy.url("http://www.example.com/upload").unwrap();
    easy.post(true).unwrap();
    easy.post_field_size(data.len() as u64).unwrap();

    let mut transfer = easy.transfer();
    transfer.read_function(|buf| {
        Ok(data.read(buf).unwrap_or(0))
    }).unwrap();
    transfer.perform().unwrap();
}

自定义头

可以在请求中指定自定义头

use curl::easy::{Easy, List};

fn main() {
    let mut easy = Easy::new();
    easy.url("http://www.example.com").unwrap();

    let mut list = List::new();
    list.append("Authorization: Basic QWxhZGRpbjpvcGVuIHNlc2FtZQ==").unwrap();
    easy.http_headers(list).unwrap();
    easy.perform().unwrap();
}

保持连接

可以在多个请求之间重用句柄。Curl将尝试保持连接活跃。

use curl::easy::Easy;

fn main() {
    let mut handle = Easy::new();

    handle.url("http://www.example.com/foo").unwrap();
    handle.perform().unwrap();

    handle.url("http://www.example.com/bar").unwrap();
    handle.perform().unwrap();
}

多个请求

libcurl库通过“multi”接口提供支持,可以同时发送多个请求。这目前在crate的 multi 模块中实现,并提供同时执行多个传输的能力。有关更多信息,请参阅该模块。

构建

默认情况下,此crate将尝试动态链接到系统范围内的libcurl和系统范围内的SSL库。可以使用各种Cargo功能自定义一些此行为

  • ssl:使用平台默认的TLS后端启用SSL/TLS支持。在Windows上这是 Schannel,在macOS上是 Secure Transport,在其他所有平台上是 OpenSSL(或等效)。默认启用。

  • rustls 通过 Rustls 启用SSL/TLS支持,这是一个用Rust编写的广受欢迎的替代TLS后端。Rustls始终是静态链接。默认禁用。

    请注意,Rustls 在 Curl 中的支持是实验性的,并且可能存在重大错误,因此我们不会对这项功能提供任何稳定性保证。

  • http2:通过 libnghttp2 启用 HTTP/2 支持。默认禁用。

  • static-curl:使用捆绑的 libcurl 版本并将其静态链接。默认禁用。

  • static-ssl:使用捆绑的 OpenSSL 版本并将其静态链接。仅适用于使用 OpenSSL 的平台。默认禁用。

  • spnego:启用 SPNEGO 支持。默认禁用。

  • upkeep_7_62_0:启用 curl_easy_upkeep() 支持,该支持在 curl 7.62.0 中引入。默认禁用。

  • poll_7_68_0:启用 curl_multi_poll()/curl_multi_wakeup() 支持,需要 curl 7.68.0 或更高版本。默认禁用。

  • ntlm:在 curl 中启用 NTLM 支持。默认禁用。

  • windows-static-ssl:通过 vcpkg 提供的静态构建启用 Windows 上的 Openssl 支持。与 ssl 不兼容(使用 --no-default-features)。默认禁用。

    请注意,要在 Windows 上通过 vcpkg 安装 openssl,需要运行以下命令

    git clone https://github.com/microsoft/vcpkg
    cd vcpkg
    ./bootstrap-vcpkg.bat -disableMetrics
    ./vcpkg.exe integrate install
    ./vcpkg.exe install openssl:x64-windows-static-md
    

版本支持

这些绑定是在 curl 版本 7.24.0 下开发的。它们应该与任何新的 curl 版本兼容,并且可能也与旧版本兼容,但这尚未经过测试。

故障排除

Curl 链接了 NSS SSL 库

如果您遇到以下错误信息

  [77] Problem with the SSL CA cert (path? access rights?)

这意味着最有可能的情况是,由于已安装的 libcurl NSS 开发文件,curl 链接到了 libcurl-nss.so,并且所需的库 libnsspem.so 丢失。另请参阅 curl 的 man 页面:“如果 curl 是针对 NSS SSL 库构建的,则 NSS PEM PKCS#11 模块(libnsspem.so)需要可用才能使此选项正常工作。”

为了避免这种失败,您可以选择

  • 安装缺失的库(例如 Debian:nss-plugin-pem),或者
  • 删除 libcurl NSS 开发文件(例如 Debian:libcurl4-nss-dev)并重新构建 curl-rust。

许可

curl-rust 软件包遵循 MIT 许可证,有关更多详细信息,请参阅 LICENSE

依赖项

~1–12MB
~163K SLoC