2024-03-31 17:52:28 +08:00
|
|
|
<!--
|
|
|
|
Copyright (C) Daniel Stenberg, <daniel@haxx.se>, et al.
|
|
|
|
|
|
|
|
SPDX-License-Identifier: curl
|
|
|
|
-->
|
|
|
|
|
2020-10-13 23:34:40 +08:00
|
|
|
# Features -- what curl can do
|
2000-05-23 01:35:35 +08:00
|
|
|
|
2020-10-13 23:34:40 +08:00
|
|
|
## curl tool
|
2000-05-23 01:35:35 +08:00
|
|
|
|
2004-08-12 22:08:46 +08:00
|
|
|
- config file support
|
|
|
|
- multiple URLs in a single command line
|
|
|
|
- range "globbing" support: [0-13], {one,two,three}
|
|
|
|
- multiple file upload on a single command line
|
2022-09-21 05:30:19 +08:00
|
|
|
- redirect stderr
|
2020-10-13 23:34:40 +08:00
|
|
|
- parallel transfers
|
|
|
|
|
|
|
|
## libcurl
|
2004-08-12 22:08:46 +08:00
|
|
|
|
2023-11-22 18:34:13 +08:00
|
|
|
- URL RFC 3986 syntax
|
2000-05-23 01:35:35 +08:00
|
|
|
- custom maximum download time
|
2024-07-03 06:04:39 +08:00
|
|
|
- custom lowest download speed acceptable
|
2000-05-23 01:35:35 +08:00
|
|
|
- custom output result after completion
|
2024-01-23 22:12:09 +08:00
|
|
|
- guesses protocol from hostname unless specified
|
2024-07-03 06:04:39 +08:00
|
|
|
- supports .netrc
|
2013-03-19 06:43:16 +08:00
|
|
|
- progress bar with time statistics while downloading
|
2024-07-03 06:04:39 +08:00
|
|
|
- standard proxy environment variables support
|
|
|
|
- have run on 101 operating systems and 28 CPU architectures
|
2003-06-26 19:36:32 +08:00
|
|
|
- selectable network interface for outgoing traffic
|
2022-04-21 23:05:36 +08:00
|
|
|
- IPv6 support on Unix and Windows
|
2024-07-03 06:04:39 +08:00
|
|
|
- happy eyeballs dual-stack IPv4 + IPv6 connects
|
2012-07-21 03:02:58 +08:00
|
|
|
- persistent connections
|
2020-10-13 23:34:40 +08:00
|
|
|
- SOCKS 4 + 5 support, with or without local name resolving
|
2024-07-03 06:04:39 +08:00
|
|
|
- *pre-proxy* support, for *proxy chaining*
|
2024-02-07 06:43:41 +08:00
|
|
|
- supports username and password in proxy environment variables
|
2020-10-13 23:34:40 +08:00
|
|
|
- operations through HTTP proxy "tunnel" (using CONNECT)
|
2012-07-21 03:02:58 +08:00
|
|
|
- replaceable memory functions (malloc, free, realloc, etc)
|
2024-07-03 06:04:39 +08:00
|
|
|
- asynchronous name resolving
|
2007-05-26 05:20:39 +08:00
|
|
|
- both a push and a pull style interface
|
2024-07-03 06:04:39 +08:00
|
|
|
- international domain names (IDN)
|
|
|
|
- transfer late limiting
|
|
|
|
- stable API and ABI
|
|
|
|
- TCP keep alive
|
|
|
|
- TCP Fast Open
|
|
|
|
- DNS cache (that can be shared between transfers)
|
|
|
|
- non-blocking single-threaded parallel transfers
|
|
|
|
- unix domain sockets to server or proxy
|
|
|
|
- DNS-over-HTTPS
|
|
|
|
- uses non-blocking name resolves
|
|
|
|
- selectable name resolver backend
|
|
|
|
|
|
|
|
## URL API
|
|
|
|
|
|
|
|
- parses RFC 3986 URLs
|
|
|
|
- generates URLs from individual components
|
|
|
|
- manages "redirects"
|
|
|
|
|
|
|
|
## Header API
|
|
|
|
|
|
|
|
- easy access to HTTP response headers, from all contexts
|
|
|
|
- named headers
|
|
|
|
- iterate over headers
|
|
|
|
|
|
|
|
## TLS
|
|
|
|
|
|
|
|
- selectable TLS backend(s)
|
|
|
|
- TLS False Start
|
|
|
|
- TLS version control
|
|
|
|
- TLS session resumption
|
|
|
|
- key pinning
|
|
|
|
- mutual authentication
|
|
|
|
- Use dedicated CA cert bundle
|
|
|
|
- Use OS-provided CA store
|
|
|
|
- separate TLS options for HTTPS proxy
|
2020-10-13 23:34:40 +08:00
|
|
|
|
|
|
|
## HTTP
|
2000-05-23 01:35:35 +08:00
|
|
|
|
2020-10-13 23:34:40 +08:00
|
|
|
- HTTP/0.9 responses are optionally accepted
|
|
|
|
- HTTP/1.0
|
|
|
|
- HTTP/1.1
|
2024-07-03 06:04:39 +08:00
|
|
|
- HTTP/2, including multiplexing and server push
|
2000-05-23 01:35:35 +08:00
|
|
|
- GET
|
|
|
|
- PUT
|
|
|
|
- HEAD
|
|
|
|
- POST
|
2023-06-25 16:50:17 +08:00
|
|
|
- multipart formpost (RFC 1867-style)
|
2024-07-03 06:04:39 +08:00
|
|
|
- authentication: Basic, Digest, NTLM (9) and Negotiate (SPNEGO)
|
2014-08-02 20:51:18 +08:00
|
|
|
to server and proxy
|
2024-07-03 06:04:39 +08:00
|
|
|
- resume transfers
|
2000-05-23 01:35:35 +08:00
|
|
|
- follow redirects
|
2000-12-11 23:35:57 +08:00
|
|
|
- maximum amount of redirects to follow
|
2000-05-23 01:35:35 +08:00
|
|
|
- custom HTTP request
|
2000-12-11 23:35:57 +08:00
|
|
|
- cookie get/send fully parsed
|
2022-01-30 19:57:24 +08:00
|
|
|
- reads/writes the Netscape cookie file format
|
2003-06-26 19:36:32 +08:00
|
|
|
- custom headers (replace/remove internally generated headers)
|
2000-05-23 01:35:35 +08:00
|
|
|
- custom user-agent string
|
2014-03-13 11:48:38 +08:00
|
|
|
- custom referrer string
|
2000-05-23 01:35:35 +08:00
|
|
|
- range
|
|
|
|
- proxy authentication
|
|
|
|
- time conditions
|
2020-10-13 23:34:40 +08:00
|
|
|
- via HTTP proxy, HTTPS proxy or SOCKS proxy
|
2024-07-03 06:04:39 +08:00
|
|
|
- HTTP/2 or HTTP/1.1 to HTTPS proxy
|
2000-12-11 23:35:57 +08:00
|
|
|
- retrieve file modification date
|
2024-07-03 06:04:39 +08:00
|
|
|
- Content-Encoding support for deflate, gzip, brotli and zstd
|
2013-03-19 06:43:16 +08:00
|
|
|
- "Transfer-Encoding: chunked" support in uploads
|
2024-07-03 06:04:39 +08:00
|
|
|
- HSTS
|
|
|
|
- alt-svc
|
|
|
|
- ETags
|
|
|
|
- HTTP/1.1 trailers, both sending and getting
|
2020-10-13 23:34:40 +08:00
|
|
|
|
2024-07-03 06:04:39 +08:00
|
|
|
## HTTPS
|
2000-05-23 01:35:35 +08:00
|
|
|
|
2024-07-03 06:04:39 +08:00
|
|
|
- HTTP/3
|
2005-05-18 18:14:25 +08:00
|
|
|
- using client certificates
|
2000-12-11 23:35:57 +08:00
|
|
|
- verify server certificate
|
2020-10-13 23:34:40 +08:00
|
|
|
- via HTTP proxy, HTTPS proxy or SOCKS proxy
|
2003-05-28 18:24:20 +08:00
|
|
|
- select desired encryption
|
2024-07-03 06:04:39 +08:00
|
|
|
- select usage of a specific TLS version
|
|
|
|
- ECH
|
2020-10-13 23:34:40 +08:00
|
|
|
|
|
|
|
## FTP
|
2000-05-23 01:35:35 +08:00
|
|
|
|
|
|
|
- download
|
|
|
|
- authentication
|
2024-07-03 06:04:39 +08:00
|
|
|
- Kerberos 5
|
2001-12-03 18:07:49 +08:00
|
|
|
- active/passive using PORT, EPRT, PASV or EPSV
|
2000-05-23 01:35:35 +08:00
|
|
|
- single file size information (compare to HTTP HEAD)
|
|
|
|
- 'type=' URL support
|
2024-01-23 22:12:09 +08:00
|
|
|
- directory listing
|
|
|
|
- directory listing names-only
|
2000-05-23 01:35:35 +08:00
|
|
|
- upload
|
|
|
|
- upload append
|
|
|
|
- upload via http-proxy as HTTP PUT
|
|
|
|
- download resume
|
|
|
|
- upload resume
|
2000-08-01 06:42:34 +08:00
|
|
|
- custom ftp commands (before and/or after the transfer)
|
2000-05-23 01:35:35 +08:00
|
|
|
- simple "range" support
|
2020-10-13 23:34:40 +08:00
|
|
|
- via HTTP proxy, HTTPS proxy or SOCKS proxy
|
|
|
|
- all operations can be tunneled through proxy
|
2000-12-11 23:35:57 +08:00
|
|
|
- customizable to retrieve file modification date
|
2024-01-23 22:12:09 +08:00
|
|
|
- no directory depth limit
|
2000-05-23 01:35:35 +08:00
|
|
|
|
2024-07-03 06:04:39 +08:00
|
|
|
## FTPS
|
2020-10-13 23:34:40 +08:00
|
|
|
|
|
|
|
- implicit `ftps://` support that use SSL on both connections
|
|
|
|
- explicit "AUTH TLS" and "AUTH SSL" usage to "upgrade" plain `ftp://`
|
2004-01-07 22:50:11 +08:00
|
|
|
connection to use SSL for both or one of the connections
|
|
|
|
|
2024-07-03 06:04:39 +08:00
|
|
|
## SSH (both SCP and SFTP)
|
2020-10-13 23:34:40 +08:00
|
|
|
|
2024-07-03 06:04:39 +08:00
|
|
|
- selectable SSH backend
|
|
|
|
- known hosts support
|
|
|
|
- public key fingerprinting
|
2007-05-26 05:20:39 +08:00
|
|
|
- both password and public key auth
|
|
|
|
|
2024-07-03 06:04:39 +08:00
|
|
|
## SFTP
|
2020-10-13 23:34:40 +08:00
|
|
|
|
2007-05-26 05:20:39 +08:00
|
|
|
- both password and public key auth
|
|
|
|
- with custom commands sent before/after the transfer
|
2024-07-03 06:04:39 +08:00
|
|
|
- directory listing
|
2007-05-26 05:20:39 +08:00
|
|
|
|
2020-10-13 23:34:40 +08:00
|
|
|
## TFTP
|
|
|
|
|
2013-03-19 06:43:16 +08:00
|
|
|
- download
|
|
|
|
- upload
|
2005-11-17 22:28:58 +08:00
|
|
|
|
2020-10-13 23:34:40 +08:00
|
|
|
## TELNET
|
|
|
|
|
2000-05-23 01:35:35 +08:00
|
|
|
- connection negotiation
|
2001-03-12 17:44:08 +08:00
|
|
|
- custom telnet options
|
2000-05-23 01:35:35 +08:00
|
|
|
- stdin/stdout I/O
|
|
|
|
|
2024-07-03 06:04:39 +08:00
|
|
|
## LDAP
|
2020-10-13 23:34:40 +08:00
|
|
|
|
2000-05-23 01:35:35 +08:00
|
|
|
- full LDAP URL support
|
|
|
|
|
2020-10-13 23:34:40 +08:00
|
|
|
## DICT
|
|
|
|
|
2000-05-23 01:35:35 +08:00
|
|
|
- extended DICT URL support
|
|
|
|
|
2020-10-13 23:34:40 +08:00
|
|
|
## FILE
|
|
|
|
|
2000-05-23 01:35:35 +08:00
|
|
|
- URL support
|
2013-03-19 06:43:16 +08:00
|
|
|
- upload
|
2004-08-12 22:08:46 +08:00
|
|
|
- resume
|
2000-05-23 01:35:35 +08:00
|
|
|
|
2020-10-13 23:34:40 +08:00
|
|
|
## SMB
|
|
|
|
|
2014-12-01 05:51:26 +08:00
|
|
|
- SMBv1 over TCP and SSL
|
|
|
|
- download
|
|
|
|
- upload
|
|
|
|
- authentication with NTLMv1
|
|
|
|
|
2020-10-13 23:34:40 +08:00
|
|
|
## SMTP
|
|
|
|
|
2024-07-03 06:04:39 +08:00
|
|
|
- authentication: Plain, Login, CRAM-MD5, Digest-MD5, NTLM, Kerberos 5 and
|
|
|
|
External
|
2021-12-17 18:02:18 +08:00
|
|
|
- send emails
|
2013-02-06 08:28:50 +08:00
|
|
|
- mail from support
|
|
|
|
- mail size support
|
|
|
|
- mail auth support for trusted server-to-server relaying
|
|
|
|
- multiple recipients
|
|
|
|
- via http-proxy
|
|
|
|
|
2024-07-03 06:04:39 +08:00
|
|
|
## SMTPS
|
2020-10-13 23:34:40 +08:00
|
|
|
|
|
|
|
- implicit `smtps://` support
|
|
|
|
- explicit "STARTTLS" usage to "upgrade" plain `smtp://` connections to use SSL
|
2013-02-06 08:28:50 +08:00
|
|
|
- via http-proxy
|
2013-02-06 17:29:50 +08:00
|
|
|
|
2020-10-13 23:34:40 +08:00
|
|
|
## POP3
|
|
|
|
|
2013-02-06 08:28:50 +08:00
|
|
|
- authentication: Clear Text, APOP and SASL
|
2024-07-03 06:04:39 +08:00
|
|
|
- SASL based authentication: Plain, Login, CRAM-MD5, Digest-MD5, NTLM,
|
|
|
|
Kerberos 5 and External
|
2021-12-17 18:02:18 +08:00
|
|
|
- list emails
|
|
|
|
- retrieve emails
|
2013-03-07 19:03:16 +08:00
|
|
|
- enhanced command support for: CAPA, DELE, TOP, STAT, UIDL and NOOP via
|
|
|
|
custom requests
|
2013-02-06 08:28:50 +08:00
|
|
|
- via http-proxy
|
|
|
|
|
2024-07-03 06:04:39 +08:00
|
|
|
## POP3S
|
2020-10-13 23:34:40 +08:00
|
|
|
|
|
|
|
- implicit `pop3s://` support
|
2022-09-21 05:30:19 +08:00
|
|
|
- explicit `STLS` usage to "upgrade" plain `pop3://` connections to use SSL
|
2013-02-06 08:28:50 +08:00
|
|
|
- via http-proxy
|
2013-02-06 17:29:50 +08:00
|
|
|
|
2020-10-13 23:34:40 +08:00
|
|
|
## IMAP
|
|
|
|
|
2013-02-06 08:28:50 +08:00
|
|
|
- authentication: Clear Text and SASL
|
2024-07-03 06:04:39 +08:00
|
|
|
- SASL based authentication: Plain, Login, CRAM-MD5, Digest-MD5, NTLM,
|
|
|
|
Kerberos 5 and External
|
2013-03-08 02:31:48 +08:00
|
|
|
- list the folders of a mailbox
|
2022-09-21 05:30:19 +08:00
|
|
|
- select a mailbox with support for verifying the `UIDVALIDITY`
|
2021-12-17 18:02:18 +08:00
|
|
|
- fetch emails with support for specifying the UID and SECTION
|
|
|
|
- upload emails via the append command
|
2013-03-16 19:42:17 +08:00
|
|
|
- enhanced command support for: EXAMINE, CREATE, DELETE, RENAME, STATUS,
|
2013-03-19 06:43:16 +08:00
|
|
|
STORE, COPY and UID via custom requests
|
2013-02-06 08:28:50 +08:00
|
|
|
- via http-proxy
|
|
|
|
|
2024-07-03 06:04:39 +08:00
|
|
|
## IMAPS
|
2020-10-13 23:34:40 +08:00
|
|
|
|
|
|
|
- implicit `imaps://` support
|
|
|
|
- explicit "STARTTLS" usage to "upgrade" plain `imap://` connections to use SSL
|
2013-02-06 08:28:50 +08:00
|
|
|
- via http-proxy
|
|
|
|
|
2020-10-13 23:34:40 +08:00
|
|
|
## MQTT
|
|
|
|
|
2022-03-29 19:58:11 +08:00
|
|
|
- Subscribe to and publish topics using URL scheme `mqtt://broker/topic`
|