curl/docs/FEATURES

207 lines
6.1 KiB
Plaintext
Raw Normal View History

2010-02-14 20:40:18 +01:00
_ _ ____ _
___| | | | _ \| |
/ __| | | | |_) | |
| (__| |_| | _ <| |___
2000-05-22 19:35:35 +02:00
\___|\___/|_| \_\_____|
FEATURES
2004-08-12 16:08:46 +02:00
curl tool
- 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
- custom maximum transfer rate
- redirectable stderr
- metalink support (*13)
2004-08-12 16:08:46 +02:00
libcurl
2004-08-12 16:08:46 +02:00
- full URL syntax with no length limit
2000-05-22 19:35:35 +02:00
- custom maximum download time
- custom least download speed acceptable
- custom output result after completion
- guesses protocol from host name unless specified
- uses .netrc
- progress bar with time statistics while downloading
2000-12-11 16:35:57 +01:00
- "standard" proxy environment variables support
2003-06-26 13:36:32 +02:00
- compiles on win32 (reported builds on 40+ operating systems)
- selectable network interface for outgoing traffic
2004-08-12 16:08:46 +02:00
- IPv6 support on unix and Windows
2012-07-20 21:02:58 +02:00
- persistent connections
2014-08-01 09:00:06 +02:00
- socks 4 + 5 support, with or without local name resolving
- supports user name and password in proxy environment variables
2003-06-26 13:36:32 +02:00
- operations through proxy "tunnel" (using CONNECT)
- support for large files (>2GB and >4GB) during upload and download
2012-07-20 21:02:58 +02:00
- replaceable memory functions (malloc, free, realloc, etc)
2004-08-12 16:08:46 +02:00
- asynchronous name resolving (*6)
2007-05-25 23:20:39 +02:00
- both a push and a pull style interface
- international domain names (*11)
2000-05-22 19:35:35 +02:00
HTTP
2003-06-26 13:36:32 +02:00
- HTTP/1.1 compliant (optionally uses 1.0)
2000-05-22 19:35:35 +02:00
- GET
- PUT
- HEAD
- POST
2007-05-25 23:20:39 +02:00
- Pipelining
2003-06-26 13:36:32 +02:00
- multipart formpost (RFC1867-style)
- authentication: Basic, Digest, NTLM (*9) and Negotiate (SPNEGO) (*3)
to server and proxy
- resume (both GET and PUT)
2000-05-22 19:35:35 +02:00
- follow redirects
2000-12-11 16:35:57 +01:00
- maximum amount of redirects to follow
2000-05-22 19:35:35 +02:00
- custom HTTP request
2000-12-11 16:35:57 +01:00
- cookie get/send fully parsed
2003-05-28 12:24:20 +02:00
- reads/writes the netscape cookie file format
2003-06-26 13:36:32 +02:00
- custom headers (replace/remove internally generated headers)
2000-05-22 19:35:35 +02:00
- custom user-agent string
2014-03-13 04:48:38 +01:00
- custom referrer string
2000-05-22 19:35:35 +02:00
- range
- proxy authentication
- time conditions
- via http-proxy
2000-12-11 16:35:57 +01:00
- retrieve file modification date
2003-05-28 12:24:20 +02:00
- Content-Encoding support for deflate and gzip
- "Transfer-Encoding: chunked" support in uploads
- data compression (*12)
- HTTP/2 (*5)
2000-05-22 19:35:35 +02:00
HTTPS (*1)
- (all the HTTP features)
2005-05-18 12:14:25 +02:00
- using client certificates
2000-12-11 16:35:57 +01:00
- verify server certificate
2000-05-22 19:35:35 +02:00
- via http-proxy
2003-05-28 12:24:20 +02:00
- select desired encryption
- force usage of a specific SSL version (SSLv2 (*7), SSLv3 (*10) or TLSv1)
2000-05-22 19:35:35 +02:00
FTP
- download
- authentication
- Kerberos 5 (*14)
2001-12-03 11:07:49 +01:00
- active/passive using PORT, EPRT, PASV or EPSV
2000-05-22 19:35:35 +02:00
- single file size information (compare to HTTP HEAD)
- 'type=' URL support
- dir listing
- dir listing names-only
- upload
- upload append
- upload via http-proxy as HTTP PUT
- download resume
- upload resume
2000-08-01 00:42:34 +02:00
- custom ftp commands (before and/or after the transfer)
2000-05-22 19:35:35 +02:00
- simple "range" support
- via http-proxy
2000-09-15 15:20:34 +02:00
- all operations can be tunneled through a http-proxy
2000-12-11 16:35:57 +01:00
- customizable to retrieve file modification date
2004-08-12 16:08:46 +02:00
- no dir depth limit
2000-05-22 19:35:35 +02:00
2004-01-07 15:50:11 +01:00
FTPS (*1)
- implicit ftps:// support that use SSL on both connections
- explicit "AUTH TLS" and "AUTH SSL" usage to "upgrade" plain ftp://
2004-01-07 15:50:11 +01:00
connection to use SSL for both or one of the connections
2007-05-25 23:20:39 +02:00
SCP (*8)
- both password and public key auth
SFTP (*8)
- both password and public key auth
- with custom commands sent before/after the transfer
2005-11-17 15:28:58 +01:00
TFTP
- download
- upload
2005-11-17 15:28:58 +01:00
2000-05-22 19:35:35 +02:00
TELNET
- connection negotiation
2001-03-12 10:44:08 +01:00
- custom telnet options
2000-05-22 19:35:35 +02:00
- stdin/stdout I/O
LDAP (*2)
- full LDAP URL support
DICT
- extended DICT URL support
FILE
- URL support
- upload
2004-08-12 16:08:46 +02:00
- resume
2000-05-22 19:35:35 +02:00
SMB
- SMBv1 over TCP and SSL
- download
- upload
- authentication with NTLMv1
SMTP
- authentication: Plain, Login, CRAM-MD5, Digest-MD5, NTLM (*9) and Kerberos 5
(*4)
- send e-mails
- mail from support
- mail size support
- mail auth support for trusted server-to-server relaying
- multiple recipients
- via http-proxy
SMTPS (*1)
- implicit smtps:// support
- explicit "STARTTLS" usage to "upgrade" plain smtp:// connections to use SSL
- via http-proxy
POP3
- authentication: Clear Text, APOP and SASL
- SASL based authentication: Plain, Login, CRAM-MD5, Digest-MD5, NTLM (*9) and
Kerberos 5 (*4)
- list e-mails
- retrieve e-mails
- enhanced command support for: CAPA, DELE, TOP, STAT, UIDL and NOOP via
custom requests
- via http-proxy
POP3S (*1)
- implicit pop3s:// support
- explicit "STLS" usage to "upgrade" plain pop3:// connections to use SSL
- via http-proxy
IMAP
- authentication: Clear Text and SASL
- SASL based authentication: Plain, Login, CRAM-MD5, Digest-MD5, NTLM (*9) and
Kerberos 5 (*4)
- list the folders of a mailbox
2014-03-13 04:48:38 +01:00
- select a mailbox with support for verifying the UIDVALIDITY
- fetch e-mails with support for specifying the UID and SECTION
- upload e-mails via the append command
- enhanced command support for: EXAMINE, CREATE, DELETE, RENAME, STATUS,
STORE, COPY and UID via custom requests
- via http-proxy
IMAPS (*1)
- implicit imaps:// support
- explicit "STARTTLS" usage to "upgrade" plain imap:// connections to use SSL
- via http-proxy
2003-09-19 14:55:35 +02:00
FOOTNOTES
=========
*1 = requires OpenSSL, GnuTLS, NSS, yassl, axTLS, PolarSSL, WinSSL (native
2014-10-13 16:33:47 +02:00
Windows), Secure Transport (native iOS/OS X) or GSKit (native IBM i)
2003-06-26 13:36:32 +02:00
*2 = requires OpenLDAP
*3 = requires a GSS-API implementation (such as Heimdal or MIT Kerberos) or
SSPI (native Windows)
*4 = requires a GSS-API implementation, however, only Windows SSPI is
currently supported
*5 = requires nghttp2 and possibly a recent TLS library
2004-08-12 16:08:46 +02:00
*6 = requires c-ares
2014-10-13 16:33:47 +02:00
*7 = requires OpenSSL, NSS, GSKit, WinSSL or Secure Transport; GnuTLS, for
example, only supports SSLv3 and TLSv1
2007-05-25 23:20:39 +02:00
*8 = requires libssh2
*9 = requires OpenSSL, GnuTLS, NSS, yassl, Secure Transport or SSPI (native
Windows)
*10 = requires any of the SSL libraries in (*1) above other than axTLS, which
does not support SSLv3
*11 = requires libidn or Windows
*12 = requires libz
*13 = requires libmetalink, and either an Apple or Microsoft operating
system, or OpenSSL, or GnuTLS, or NSS
*14 = requires a GSS-API implementation (such as Heimdal or MIT Kerberos)