Linux curl命令使用教程介绍Linux如何使用curl命令?与服务器之间传输数据需要支持必要网络协议的工具。Linux 有多种为此目的而创建的工具,最受欢迎的是 curl 和wget。
Linux curl命令如何使用?本教程将向你展示如何使用该curl
命令并为你提供可用选项的详尽列表。
先决条件
- 访问终端
- 互联网
- curl安装
sudo apt 安装curl
什么是 curl 命令?
curl
(“客户端 URL”的缩写)是一个命令行工具,可以通过各种网络协议进行数据传输。它通过指定相关的 URL 和需要发送或接收的数据与Web 或应用程序服务器进行通信。curl
由 libcurl 提供支持,libcurl 是一个便携式客户端 URL 传输库。你可以直接在命令行上使用它或将其包含在脚本中。最常见的用例curl
是:- 从互联网下载文件
- 端点测试
- 调试
- 错误记录
curl
语法如下:curl [
options/URLs]
例如:
curl https://www.gnu.org/gnu/gnu.html
Linux curl命令如何使用?系统输出在
curl
命令后提供的 URL 上找到的 HTML 内容。![Linux curl命令如何使用(用法示例介绍)](http://img.readke.com/220419/152339AR-0.png)
文章图片
Linux如何使用curl命令?如果指定指向文件的 URL,则可以使用
curl
将文件下载到本地系统:curl [
url] > [
local-file]
进度条显示到目前为止已下载了多少文件。
![Linux curl命令如何使用(用法示例介绍)](http://img.readke.com/220419/15233aY0-1.png)
文章图片
作为命令一部分的 URL 的语法取决于协议。一个部分不同的多个 URL 使用大括号写在一起:
http:/
/
example.{first,second,third}.com
字母数字系列用括号表示:
ftp://ftp.url.com/file[
1-100].txt
虽然不支持嵌套序列,但允许多个序列:
http:/
/
url.com/archive[
2010-2020]/vol[
1-4]/part{a,b,c}.html
Linux curl命令使用教程:curl协议curl 支持多种数据传输协议。找到下面的完整列表。
协议 | 描述 |
---|---|
字典 | 一个字典网络协议,用于向字典服务器查询单词的含义。 |
文件 | 使用 curl 从本地文件系统获取文件的 URL 方案。 |
FTP、FTPS | 文件传输协议,用于客户端和服务器之间的文件传输。FTPS是相同协议的版本,增加了 SSL/TLS 安全层。 |
地鼠,地鼠 | 一种用于搜索、检索和分发 Internet 文档的旧协议,是 HTTP 的前身。GOPHERS 是相同协议的版本,增加了SSL/TLS安全层。 |
HTTP、HTTPS | 超文本传输??协议,用于网络和互联网数据传输。HTTPS 是相同协议的版本,但添加了 SSL/TLS 安全层。 |
IMAP, IMAP | Internet 消息访问协议,用于电子邮件访问和管理。IMAPS 是相同协议的版本,增加了 SSL/TLS 安全层。 |
LDAP、LDAPS | 轻量级目录访问协议,用于分布式目录信息的访问和管理。LDAPS 是相同协议的版本,增加了 SSL/TLS 安全层。 |
MQTT | 消息队列遥测传输——一种用于小型设备(通常是物联网系统)之间数据交换的协议。 |
POP3、POP3S | 邮局协议版本 3 - 从服务器检索电子邮件的协议。POP3S 是相同协议的版本,增加了 SSL/TLS 安全层。 |
RTMP | 实时消息传递协议 - 音频、视频和其他数据的流协议。 |
实时服务提供商 | Real Time Streaming Protocol,用于流媒体服务器管理。 |
SCP | 安全复制 - 用于将文件复制到 SSH 服务器和从 SSH 服务器复制文件的协议。 |
SFTP | SSH文件传输协议 - 使用 SSH 连接的文件传输协议的一个版本。 |
中小企业、中小企业 | 服务器消息块 - 用于管理对文件和计算机外围设备的共享访问的协议。SMBS 是相同协议的版本,增加了 SSL/TLS 安全层。 |
SMTP、SMPTS | 简单邮件传输协议 - 一种用于轻松传输电子邮件的电子邮件协议。SMTPS 是相同协议的版本,增加了 SSL/TLS 安全层。 |
远程登录 | 双向交互式文本导向通信的应用层协议。 |
TFTP | 普通文件传输协议,用于向远程主机上传文件或从远程主机下载文件。 |
curl
接受广泛的选项,这使它成为一个非常通用的命令。选项以一两个破折号开头。如果它们不需要附加值,则可以将单破折号选项写在一起。例如,利用该命令-O
,-L
和-v
选项可以写为:curl -OLv [
url]
Linux curl命令如何使用?下面给出了所有可用选项的列表。
选项 | 描述 |
---|---|
--abstract-unix-socket <
path>
| 通过抽象的 Unix 套接字而不是通过网络连接。 例子: curl --abstract-unix-socket socketpath https://example.com |
--alt-svc <
file name>
| 启用 alt-svc 解析器。 例子: curl --alt-svc svc.txt https://example.com |
--anyauth | Curl 为给定的 HTTP URL 查找并使用最安全的身份验证方法。 例子: curl --anyauth --user me:pass https://example.com |
-a, --append | 附加到目标文件。 例子: curl --upload-file local --append ftp://example.com/ |
--aws-sigv4 <
provider1[:provider2[:region[:service]]]>
| 使用 AWS V4 签名身份验证。 例子: curl --aws-sigv4 "aws:amz:east-2:es" --user "key:secret" https://example.com |
--basic | 使用 HTTP 基本身份验证。
例子: curl -u name:password --basic https://example.com |
--cacert <
file>
| 使用指定的文件进行证书验证。 Linux curl命令用法示例: curl --cacert CA-file.txt https://example.com |
--capath <
dir>
| 使用指定的目录查找证书。 例子: curl --capath /local/directory https://example.com |
--cert-status | 验证服务器证书状态。 例子: curl --cert-status https://example.com |
--cert-type <
type>
| 指定所提供证书的类型。可识别的类型为PEM (默认)DER 、ENG 和P12 。例子: curl --cert-type ENG --cert file https://example.com |
-E, --cert <
certificate[:password]>
| 使用基于 SSL 的协议时使用提供的证书文件。 例子: curl --cert certfile --key keyfile https://example.com |
--ciphers <
list of ciphers>
| 提供要在连接中使用的密码。 例子: curl --ciphers ECDHE-ECDSA-AES256-CCM8 https://example.com |
--compressed-ssh | 启用内置 SSH 压缩。
例子: curl --compressed-ssh sftp://example.com/ |
--compressed | 请求接收压缩响应。
例子: curl --compressed https://example.com
|
-K, --config <
file>
| 提供带有 curl 参数的文本文件,而不是将它们写在命令行上。
例子: curl --config file.txt https://example.com |
--connect-timeout <
fractional seconds>
| 指定 curl 连接可以持续的最长时间。 例子: curl --connect-timeout 30 https://example.com |
--connect-to <
HOST1:PORT1:HOST2:PORT2>
| 提供连接规则以将请求定向到特定服务器集群节点。
例子: curl --connect-to example.com:443:example.net:8443 https://example.com |
-C, --continue-at <
offset>
| 在指定的偏移量处恢复文件传输。curl -C 400 https://example.com |
-c, --cookie-jar <
filename>
| 指定用于存储 cookie 的文件。curl -c store.txt https://example.com |
-b, --cookie <
data|filename>
| 从文件中读取 cookie。
例子: curl -b cookiefile https://example.com |
--create-dirs | 为--output 选项创建本地目录。
例子: curl --create-dirs --output local/dir/file https://example.com |
--create-file-mode <
mode>
| 指定在创建文件时设置的模式。
例子: curl --create-file-mode 0777 -T localfile sftp://example.com/new |
--crlf | 将 LF 转换为 CRLF。
curl --crlf -T file ftp://example.com/ |
--crlfile <
file>
| 为对等证书提供证书吊销列表。
curl --crlfile revoke.txt https://example.com |
--curves <
algorithm list>
| 提供建立 SSL 会话的curl。 例子: curl --curves X25519 https://example.com |
--data-ascii <
data>
| 见-d ,--data 。
例子: curl --data-ascii @file https://example.com |
--data-binary <
data>
| 按指定发布数据,无需额外处理。
curl --data-binary @filename https://example.com |
--data-raw <
data>
| 与-d ,相同--data ,但 @ 字符的处理方式与其他字符没有区别。
curl --data-raw "@at@at@" https://example.com |
--data-urlencode <
data>
| 与-d ,相同--data ,但执行 URL 编码。例子: curl --data-urlencode name=val https://example.com |
-d, --data <
data>
| 在 POST 请求中将数据发送到 HTTP 服务器。
例子: curl -d "name=curl" https://example.com |
--delegation <
LEVEL>
| 指定何时允许服务器委派凭据。
例子: curl --delegation "always" https://example.com |
--digest | 启用 HTTP 摘要身份验证。
例子: curl -u name:password --digest https://example.com |
--disable-eprt | 禁用用于活动 FTP 传输的 EPRT 和 LPRT 命令。
例子: curl --disable-eprt ftp://example.com/ |
--disable-epsv | 为被动 FTP 传输禁用 EPSV。 例子: curl --disable-epsv ftp://example.com/ |
-q, --disable | 禁用读取 curlrc 配置文件。curl -q https://example.com
|
--disallow-username-in-url | 如果提供包含用户名的 URL,则退出。
例子: curl --disallow-username-in-url https://example.com |
--dns-interface <
interface>
| 指定用于传出 DNS 请求的接口。
例子: curl --dns-interface eth0 https://example.com |
--dns-ipv4-addr <
address>
| 指定 DNS 请求将来自的 IPv4 地址。
例子: curl --dns-ipv4-addr 10.1.2.3 https://example.com |
--dns-ipv6-addr <
address>
| 指定 DNS 请求将来自的 IPv6 地址。
例子: curl --dns-ipv6-addr 2a04:4e42::561 https://example.com |
--dns-servers <
addresses>
| 指定你自己的 DNS 服务器列表。
例子: curl --dns-servers 192.168.0.1,192.168.0.2 https://example.com |
--doh-cert-status | --cert-status 用于 DNS-over-HTTPS。
例子: curl --doh-cert-status --doh-url https://doh.server https://example.com
|
--doh-insecure | -k ,--insecure 对于 DoH。例子: curl --doh-insecure --doh-url https://doh.server https://example.com |
--doh-url <
URL>
| 为主机名解析指定 DoH 服务器。
例子: curl --doh-url https://doh.server https://example.com
|
-D, --dump-header <
filename>
| 指定用于写入协议头的文件。
例子: curl --dump-header store.txt https://example.com
|
--egd-file <
file>
| 提供 EGD 插座的路径。
例子: curl --egd-file /path/here https://example.com
|
--engine <
name>
| 指定 OpenSSL 加密引擎。 例子: curl --engine flavor https://example.com
|
--etag-compare <
file>
| 请求从文件中读取 ETag。 例子: curl --etag-compare etag.txt https://example.com
|
--etag-save <
file>
| 将 HTTP ETag 保存到文件。
例子: curl --etag-save etag.txt https://example.com
|
--expect100-timeout <
seconds>
| 100-continue 响应的最长等待时间。
例子: curl --expect100-timeout 2.5 -T file https://example.com
|
--fail-early | 当 curl 检测到传输中的第一个错误时,告诉 curl 失败并退出。
例子: curl --fail-early https://example.com https://two.example
|
--fail-with-body | 如果服务器返回代码为 400 或更大的错误,curl 保存内容并返回错误 22。
示例: curl --fail-with-body https://example.com
|
-f, --fail | 如果服务器返回错误,curl 会静默失败并返回错误 22。
示例: curl --fail https://example.com
|
--false-start | 在 TLS 握手时使用错误启动。
例子: curl --false-start https://example.com
|
--form-string <
name=string>
| 与-F ,类似--form ,但按字面处理值字符串。
例子: curl --form-string "data" https://example.com
|
-F, --form <
name=content>
| 使用已按下的提交按钮模拟表单。该@ 符号强制内容为文件。该<
符号仅提取文件的内容部分。
例子: curl --form "name=curl" --form "file=@loadthis" https://example.com |
--ftp-account <
data>
| 指定 FTP 服务器的帐户数据。
例子: curl --ftp-account "account_data" ftp://example.com/ |
--ftp-alternative-to-user <
command>
| 指定用户名密码认证失败时发送的命令。
例子: curl --ftp-alternative-to-user "U53r" ftp://example.com
|
--ftp-create-dirs | 如果指定的目录不存在,curl 将尝试创建它。 例子: curl --ftp-create-dirs -T file ftp://example.com/dirs/one/file
|
--ftp-method <
method>
| 指定用于通过 FTP 获取文件的方法。可用的方法是multicwd ,nocwd 和singlecwd 。
例子: curl --ftp-method multicwd ftp://example.com/dir1/dir2/file
|
--ftp-pasv | 使用被动数据连接模式。
例子: curl --ftp-pasv ftp://example.com/
|
-P, --ftp-port <
address>
| 反转 FTP 连接的默认角色。
例子: curl -P eth0 ftp:/example.com
|
--ftp-pret | 在 PASV/EPSV 之前发送 PRET 命令。 例子: curl --ftp-pret ftp://example.com/
|
--ftp-skip-pasv-ip | 不要使用服务器建议的 IP 地址。curl 将使用控制连接 IP。
例子: curl --ftp-skip-pasv-ip ftp://example.com/
|
--ftp-ssl-ccc-mode <
active/passive>
| 设置清除命令通道 (CCC) 模式。 例子: curl --ftp-ssl-ccc-mode active --ftp-ssl-ccc ftps://example.com/
|
--ftp-ssl-ccc | 身份验证完成后,SSL/TLS 层被消除,允许未加密的通信。
例子: curl --ftp-ssl-ccc ftps://example.com/
|
--ftp-ssl-control | 使用 SSL/TLS 登录,数据传输开始时停止加密。 例子: curl --ftp-ssl-control ftp://example.com
|
-G, --get | 使用 HTTP GET 请求而不是 POST。
例子: curl --get -d "tool=curl" -d "age=old" https://example.com |
-g, --globoff | 禁用 URL globbing 解析器。 例子: curl -g "https://example.com/{[]}}}}"
|
--happy-eyeballs-timeout-ms <
milliseconds>
| 使用 Happy Eyeballs 算法连接双栈主机。
例子: curl --happy-eyeballs-timeout-ms 500 https://example.com
|
--haproxy-protocol | 使用 HAProxy PROXY 协议 v1 标头。
例子: curl --haproxy-protocol https://example.com
|
-I, --head | 仅获取标题。 例子: curl -I https://example.com
|
-H, --header <
header/@file>
| 指定要在 HTTP 请求中发送的附加标头。
例子: curl -H "X-First-Name: Joe" https://example.com
|
-h, --help <
category>
| 请参阅特定类别的帮助。all 列出所有可用选项。
例子: curl --help all
|
--hostpubmd5 <
md5>
| 传递 32 位十六进制字符串。
例子: curl --hostpubmd5 e5c1c49020640a5ab0f2034854c321a8 sftp://example.com/
|
--hsts <
file name>
| 启用 HSTS。
例子: curl --hsts cache.txt https://example.com
|
--http0.9 | 接受 HTTP 版本 0.9 响应。
例子: curl --http0.9 https://example.com |
-0, --http1.0 | 使用 HTTP 版本 1.0。
例子: curl --http1.0 https://example.com |
--http1.1 | 使用 HTTP 版本 1.1。
例子: curl --http1.1 https://example.com
|
--http2-prior-knowledge | 使用 HTTP 2.0 版。如果你知道服务器支持此 HTTP 版本,请使用此选项。
例子: curl --http2-prior-knowledge https://example.com |
--http2 | 尝试使用 HTTP 2.0 版。
例子: curl --http2 https://example.com |
--http3 | 使用 HTTP 3.0 版。这是一个实验选项。
例子: curl --http3 https://example.com |
--ignore-content-length | 忽略 Content-Length 标头。 例子: curl --ignore-content-length https://example.com
|
-i, --include | 指定输出应包含 HTTP 响应标头。
例子: curl -i https://example.com |
-k, --insecure | 允许 curl 处理不安全的连接。
例子: curl --insecure https://example.com
|
--interface <
name>
| 指定用于执行操作的接口。
例子: curl --interface eth0 https://example.com
|
-4, --ipv4 | 仅将名称解析为 IPv4 地址。
例子: curl --ipv4 https://example.com
|
-6, --ipv6 | 仅将名称解析为 IPv6 地址。 例子: curl --ipv6 https://example.com |
-j, --junk-session-cookies | 丢弃会话 cookie。
例子: curl --junk-session-cookies -b cookies.txt https://example.com
|
--keepalive-time <
seconds>
| 指定连接在发送保活探测之??前的空闲时间。
例子: curl --keepalive-time 30 https://example.com
|
--key-type <
type>
| 指定私钥的类型。可用类型为PEM (默认)DER 、 和ENG 。
例子: curl --key-type ENG --key here https://example.com
|
--key <
key>
| 指定包含私钥的文件。
例子: curl --cert certificate --key here https://example.com
|
--krb <
level>
| 启用和使用 Kerberos 身份验证。可用级别为clear 、safe 、confidential 和private (默认)。
例子: curl --krb clear ftp://example.com/
|
--libcurl <
file>
| 获取指定命令行操作的 C 源代码。
例子: curl --libcurl client.c https://example.com
|
--limit-rate <
speed>
| 指定最大上传和下载传输速率。
例子: curl --limit-rate 100K https://example.com
|
-l, --list-only | 强制仅名称视图。
例子: curl --list-only ftp://example.com/dir/
|
--local-port <
num/range>
| 指定用于连接的端口号。
例子: curl --local-port 1000-3000 https://example.com
|
--location-trusted | 类似于-L ,
--location ,但允许你将名称和密码发送到所有重定向。例子: curl --location-trusted -u user:pass https://example.com |
-L, --location | 允许 curl 跟随任何重定向。
例子: curl -L https://example.com
|
--login-options <
options>
| 指定电子邮件服务器身份验证的登录选项。
例子: curl --login-options 'AUTH=*' imap://example.com
|
--mail-auth <
address>
| 提供一个地址作为身份。
例子: curl --mail-auth user@example.come -T mail smtp://example.com/
|
--mail-from <
address>
| 提供一个“发件人”地址。 例子: curl --mail-from user@example.com -T mail smtp://example.com/
|
--mail-rcpt-allowfails | 如果收件人之一失败,则允许 curl 继续进行 SMTP 对话。
例子: curl --mail-rcpt-allowfails --mail-rcpt dest@example.com smtp://example.com
|
--mail-rcpt <
address>
| 提供一个“收件人”地址。
例子: curl --mail-rcpt user@example.net smtp://example.com
|
-M, --manual | 阅读 curl 手册。
例子: curl --manual
|
--max-filesize <
bytes>
| 提供要下载的文件的最大大小。
例子: curl --max-filesize 500K https://example.com
|
--max-redirs <
num>
| 指定活动时的最大重定向数--location 。
例子: curl --max-redirs 3 --location https://example.com
|
-m, --max-time <
fractional seconds>
| 指定操作的最长时间。
例子: curl --max-time 5.52 https://example.com
|
--metalink | 指定一个 metalink 资源。此选项在最新版本的 curl 中被禁用。
例子: curl --metalink file https://example.com
|
--negotiate | 启用 SPNEGO 身份验证。
例子: curl --negotiate -u : https://example.com |
--netrc-file <
filename>
| 类似于--n ,
--netrc ,但允许你指定要使用的文件。
例子: curl --netrc-file netrc https://example.com
|
--netrc-optional | 像--n ,
--netrc ,但使用 netrc 是可选的。
例子: curl --netrc-optional https://example.com
|
-n, --netrc | 在 netrc 文件中搜索登录信息。 例子: curl --netrc https://example.com
|
-:, --next | 使用该选项来分隔 URL 请求。
例子: curl -I https://example.com --next https://example.net/
|
--no-alpn | 禁用 ALPN TLS 扩展。
例子: curl --no-alpn https://example.com
|
-N, --no-buffer | 禁用输出流缓冲区。
例子: curl --no-buffer https://example.com
|
--no-keepalive | 禁用保活消息。
例子: curl --no-keepalive https://example.com
|
--no-npn | 禁用 NPN TLS 扩展。
例子: curl --no-npn https://example.com
|
--no-progress-meter | 禁用进度条但显示任何其他消息。
例子: curl --no-progress-meter -o store https://example.com
|
--no-sessionid | 禁用 SSL session-ID 的缓存。
例子: curl --no-sessionid https://example.com
|
--noproxy <
no-proxy-list>
| 列出不应使用代理的主机。
例子: curl --noproxy "www.example" https://example.com
|
--ntlm-wb | 像--ntlm ,但也将身份验证交给 ntlmauth。例子: curl --ntlm-wb -u user:password https://example.com
|
--ntlm | 启用 NTLM 身份验证。
例子: curl --ntlm -u user:password https://example.com
|
--oauth2-bearer <
token>
| 为 OAUTH 2.0 提供承载令牌。
例子: curl --oauth2-bearer "mF_9.B5f-4.1JqM" https://example.com
|
--output-dir <
dir>
| 指定输出文件目录。 例子: curl --output-dir "tmp" -O https://example.com
|
-o, --output <
file>
| 将输出存储在文件中。输出未显示在标准输出中。
例子: curl -o file https://example.com -o file2 https://example.net
|
--parallel-immediate | 比等待新连接或多路复用流更喜欢并行连接。
例子: curl --parallel-immediate -Z https://example.com -o file1 https://example.com -o file2 |
--parallel-max <
num>
| 指定最大并行连接数。 Linux curl命令用法示例: curl --parallel-max 100 -Z https://example.com ftp://example.com/ |
-Z, --parallel | 并行执行传输。 例子: curl --parallel https://example.com -o file1 https://example.com -o file2 |
--pass <
phrase>
| 指定私钥密码。
例子: curl --pass secret --key file https://example.com
|
--path-as-is | 防止 curl 合并/./ 和/../ 排序。
例子: curl --path-as-is https://example.com/../../etc/passwd |
--pinnedpubkey <
hashes>
| 指定 curl 使用的公钥。
例子: curl --pinnedpubkey keyfile https://example.com
|
--post301 | 防止 curl 在 301 重定向后将 POST 转换为 GET 请求。
例子: curl --post301 --location -d "data" https://example.com
|
--post302 | 防止 curl 在 302 重定向后将 POST 转换为 GET 请求。
curl --post302 --location -d "data" https://example.com
|
--post303 | 防止 curl 在 303 重定向后将 POST 转换为 GET 请求。
例子: curl --post303 --location -d "data" https://example.com
|
--preproxy [protocol://]host[:port] | 使用 SOCKS 代理作为预代理。
例子: curl --preproxy socks5://proxy.example -x http://http.example https://example.com
|
-#, --progress-bar | 使用简单的进度条。 例子: curl -# -O https://example.com
|
--proto-default <
protocol>
| 指定 curl 应该对没有方案名称的 URL 使用哪个协议。
例子: curl --proto-default https ftp.example.com
|
--proto-redir <
protocols>
| 指定 curl 应该在重定向时使用哪些协议。
例子: curl --proto-redir =http,https https://example.com
|
--proto <
protocols>
| 指定 curl 应该使用哪些协议进行传输。
例子: curl --proto =http,https,sftp https://example.com
|
--proxy-anyauth | Curl 应该选择合适的身份验证方法。
例子: curl --proxy-anyauth --proxy-user user:passwd -x proxy https://example.com |
--proxy-basic | 使用 HTTP Basic 与代理进行通信。
例子: curl --proxy-basic --proxy-user user:passwd -x proxy https://example.com
|
--proxy-cacert <
file>
| --cacert 对于 HTTPS 代理。
例子: curl --proxy-cacert CA-file.txt -x https://proxy https://example.com
|
--proxy-capath <
dir>
| --capath 对于 HTTPS 代理。
例子: curl --proxy-capath /local/directory -x https://proxy https://example.com |
--proxy-cert-type <
type>
| --cert-type 对于 HTTPS 代理。
例子: curl --proxy-cert-type PEM --proxy-cert file -x https://proxy https://example.com |
--proxy-cert <
cert[:passwd]>
| -E ,--cert 用于 HTTPS 代理。
例子: curl --proxy-cert file -x https://proxy https://example.com
|
--proxy-ciphers <
list>
| --ciphers
对于 HTTPS 代理。
curl --proxy-ciphers ECDHE-ECDSA-AES256-CCM8 -x https://proxy https://example.com
|
--proxy-crlfile <
file>
| --crlfile 对于 HTTPS 代理。
例子: curl --proxy-crlfile rejects.txt -x https://proxy https://example.com |
--proxy-digest | 将 HTTP Digest 身份验证与代理一起使用。
例子: curl --proxy-digest --proxy-user user:passwd -x proxy https://example.com
|
--proxy-header <
header/@file>
| -H ,--header 用于代理通信。
例子: curl --proxy-header "Host:" -x http://proxy https://example.com
|
--proxy-insecure | -k ,--insecure 用于 HTTPS 代理。
例子: curl --proxy-insecure -x https://proxy https://example.com
|
--proxy-key-type <
type>
| --key-type 对于 HTTPS 代理。
例子: curl --proxy-key-type DER --proxy-key here -x https://proxy https://example.com
|
--proxy-key <
key>
| --key 对于 HTTPS 代理。
例子: curl --proxy-key here -x https://proxy https://example.com
|
--proxy-negotiate | --negotiate 用于代理通信。例子: curl --proxy-negotiate --proxy-user user:passwd -x proxy https://example.com |
--proxy-ntlm | 将 HTTP NTLM 身份验证与代理一起使用。 例子: curl --proxy-ntlm --proxy-user user:passwd -x http://proxy https://example.com |
--proxy-pass <
phrase>
| --pass 对于 HTTPS 代理。
例子: curl --proxy-pass secret --proxy-key here -x https://proxy https://example.com
|
--proxy-pinnedpubkey <
hashes>
| 指定用于代理验证的公钥。
例子: curl --proxy-pinnedpubkey keyfile https://example.com
|
--proxy-service-name <
name>
| 指定代理通信的服务名称。
例子: curl --proxy-service-name "shrubbery" -x proxy https://example.com
|
--proxy-ssl-allow-beast | --ssl-allow-beast 对于 HTTPS 代理。
例子: curl --proxy-ssl-allow-beast -x https://proxy https://example.com
|
--proxy-ssl-auto-client-cert | --ssl-auto-client-cert 对于 HTTPS 代理。
例子: curl --proxy-ssl-auto-client-cert -x https://proxy https://example.com
|
--proxy-tls13-ciphers <
ciphersuite list>
| 指定用于为代理协商 TLS 1.3 的密码套件列表。
例子: curl --proxy-tls13-ciphers TLS_AES_128_GCM_SHA256 -x proxy https://example.com |
--proxy-tlsauthtype <
type>
| --tlsauthtype 对于 HTTPS 代理。
例子: curl --proxy-tlsauthtype SRP -x https://proxy https://example.com
|
--proxy-tlspassword <
string>
| --tlspassword 对于 HTTPS 代理。例子: curl --proxy-tlspassword passwd -x https://proxy https://example.com
|
--proxy-tlsuser <
name>
| --tlsuser 对于 HTTPS 代理。
例子: curl --proxy-tlsuser smith -x https://proxy https://example.com
|
--proxy-tlsv1 | -1 ,--tlsv1 用于 HTTPS 代理。
例子: curl --proxy-tlsv1 -x https://proxy https://example.com
|
-U, --proxy-user <
user:password>
| 指定用于通过代理进行身份验证的用户名和密码。 例子: curl --proxy-user name:pwd -x proxy https://example.com
|
-x, --proxy [protocol://]host[:port] | 指定要使用的代理。 例子: curl --proxy http://proxy.example https://example.com
|
--proxy1.0 <
host[:port]>
| 指定要使用的 HTTP 1.0 代理。
例子: curl --proxy1.0 -x http://proxy https://example.com
|
-p, --proxytunnel | 创建代理隧道。 例子: curl --proxytunnel -x http://proxy https://example.com
|
--pubkey <
key>
| 提供一个包含公钥的文件。
例子: curl --pubkey file.pub sftp://example.com/
|
-Q, --quote <
command>
| 向 FTP 或 SFTP 服务器发送命令,在传输之前执行。
例子: curl --quote "rm file" ftp://example.com/foo
|
--random-file <
file>
| 指定包含随机数据的文件。此文件将用于播种随机引擎。
例子: curl --random-file rubbish https://example.com
|
-r, --range <
range>
| 获取一个字节范围。
例子: curl --range 40-80 https://example.com
|
--raw | 禁用 HTTP 内容解码并获取原始数据。
例子: curl --raw https://example.com
|
-e, --referer <
URL>
| 发送引荐页面信息。
例子: curl --referer "https://test.example" https://example.com
|
-J, --remote-header-name | 使用服务器指定的标头名称,而不是从 URL 获取它。 例子: curl -OJ https://example.com/file
|
--remote-name-all | 将-O ,--remote-name 选项应用于所有 URL。例子: curl --remote-name-all ftp://example.com/file1 ftp://example.com/file2
|
-O, --remote-name | 指定本地文件应具有下载的远程文件的名称。 例子: curl -O https://example.com/filename
|
-R, --remote-time | 指定本地文件应具有下载的远程文件的时间戳。 例子: curl --remote-time -o foo https://example.com
|
--request-target <
path>
| 指定备用目标路径。 例子: curl --request-target "*" -X OPTIONS https://example.com
|
-X, --request <
command>
| 指定与服务器通信的请求方法。 例子: curl -X "DELETE" https://example.com
|
--resolve <
[+]host:port:addr[,addr]...>
| 为主机/端口指定自定义地址。
例子: curl --resolve example.com:443:127.0.0.1 https://example.com
|
--retry-all-errors | 强制重试所有错误。 例子: curl --retry-all-errors https://example.com
|
--retry-connrefused | 将 ECONNREFUSED 添加到符合--retry .
例子: curl --retry-connrefused --retry https://example.com
|
--retry-delay <
seconds>
| 指定重试之间的时间量。
例子: curl --retry-delay 5 --retry https://example.com
|
--retry-max-time <
seconds>
| 指定--retry 尝试的最长时间。
例子: curl --retry-max-time 30 --retry 10 https://example.com
|
--retry <
num>
| 指定 curl 遇到错误后的重试次数。
例子: curl --retry 7 https://example.com |
--sasl-authzid <
identity>
| 为 SASL PLAIN 身份验证指定其他身份验证身份。
例子: curl --sasl-authzid zid imap://example.com/
|
--sasl-ir | 在 SASL 身份验证期间启用初始响应。 例子: curl --sasl-ir imap://example.com/
|
--service-name <
name>
| 指定 SPNEGO 服务名称。
例子: curl --service-name sockd/server https://example.com
|
-S, --show-error | 显示启用了-s ,--silent 选项的错误消息事件。
例子: curl --show-error --silent https://example.com
|
-s, --silent | 开启静音模式。此选项使curl静音。 例子: curl -s https://example.com
|
--socks4 <
host[:port]>
| 指定 SOCKS4 代理。 例子: curl --socks4 hostname:4096 https://example.com
|
--socks4a <
host[:port]>
| 指定 SOCKS4a 代理。
例子: curl --socks4a hostname:4096 https://example.com
|
--socks5-basic | 对 SOCKS5 代理使用基本身份验证方法(用户名/密码)。
例子: curl --socks5-basic --socks5 hostname:4096 https://example.com
|
--socks5-gssapi-nec | 允许保护模式协商不受保护。 例子: curl --socks5-gssapi-nec --socks5 hostname:4096 https://example.com
|
--socks5-gssapi-service <
name>
| 更改袜子服务器的名称。 例子: curl --socks5-gssapi-service sockd --socks5 hostname:4096 https://example.com
|
--socks5-gssapi | 将 GSS-API 身份验证与 SOCKS5 代理结合使用。
例子: curl --socks5-gssapi --socks5 hostname:4096 https://example.com
|
--socks5-hostname <
host[:port]>
| 指定要使用的 SOCKS5 代理。
例子: curl --socks5-hostname proxy.example:7000 https://example.com
|
--socks5 <
host[:port]>
| 指定要使用的 SOCKS5 代理。主机名在本地解析。
例子: curl --socks5 proxy.example:7000 https://example.com
|
-Y, --speed-limit <
speed>
| 设置下载速度的下限。 例子: curl --speed-limit 300 --speed-time 10 https://example.com
|
-y, --speed-time <
seconds>
| 设置限速测量的时间段。
例子: curl --speed-limit 300 --speed-time 10 https://example.com
|
--ssl-allow-beast | 告诉 curl 忽略 SSL3 和 TLS1.0 协议中的 BEAST 安全漏洞。
例子: curl --ssl-allow-beast https://example.com
|
--ssl-auto-client-cert | 自动获取和使用客户端证书。
例子: curl --ssl-auto-client-cert https://example.com
|
--ssl-no-revoke | 不检查证书吊销。
例子: curl --ssl-no-revoke https://example.com
|
--ssl-reqd | 需要 SSL/TLS。
例子: curl --ssl-reqd ftp://example.com
|
--ssl-revoke-best-effort | 如果由于缺少分发点而失败,则忽略证书吊销检查。 例子: curl --ssl-revoke-best-effort https://example.com
|
--ssl | 尝试使用 SSL。
例子: curl --ssl pop3://example.com/
|
-2, --sslv2 | 使用 SSLv2。由于 SSLv2 的安全问题,较新的 curl 版本会忽略此请求。 例子: curl --sslv2 https://example.com
|
-3, --sslv3 | 使用 SSLv3。由于 SSLv3 的安全问题,较新的 curl 版本会忽略此请求。
例子: curl --sslv3 https://example.com
|
--stderr <
file>
| 将 stderr 输出到文件。该- 符号告诉 curl 将 stderr 输出到 stdout。
例子: curl --stderr output.txt https://example.com
|
--styled-output | 为 HTTP 标头终端输出启用粗体。
curl --styled-output -I https://example.com
|
--suppress-connect-headers | 防止 curl 输出 CONNECT 标头。
例子: curl --suppress-connect-headers --include -x proxy https://example.com
|
--tcp-fastopen | 启用 TCP 快速打开。 例子: curl --tcp-fastopen https://example.com |
--tcp-nodelay | 启用 TCP_NODELAY。
例子: curl --tcp-nodelay https://example.com
|
-t, --telnet-option <
opt=val>
| 将TTYPE 、XDISPLOC 和NEW_ENV 选项传递给 telnet 协议。
例子: curl -t TTYPE=vt100 telnet://example.com/
|
--tftp-blksize <
value>
| 设置 TFTP BLKSIZE 的值。必须是大于 512 的值。
示例: curl --tftp-blksize 1024 tftp://example.com/file
|
--tftp-no-options | 防止 curl 发送对 TFTP 选项的请求。 例子: curl --tftp-no-options tftp://192.168.0.1/
|
-z, --time-cond <
time>
| 请求在特定日期和时间之后修改的文档。对于在该时间之前修改的文档,在日期表达式前加上破折号。 例子: curl -z "Wed 01 Sep 2021 12:18:00" https://example.com
|
--tls-max <
VERSION>
| 指定支持的最新 TLS 版本。 例子: curl --tls-max 1.2 https://example.com
|
--tls13-ciphers <
ciphersuite list>
| 指定用于协商 TLS 1.3 的密码套件列表
示例: curl --tls13-ciphers TLS_AES_128_GCM_SHA256 https://example.com
|
--tlsauthtype <
type>
| 指定 TLS 身份验证类型。 例子: curl --tlsauthtype SRP https://example.com
|
--tlspassword <
string>
| 指定 TLS 密码。
例子: curl --tlspassword pwd --tlsuser user https://example.com
|
--tlsuser <
name>
| 指定 TLS 用户名。
例子: curl --tlspassword pwd --tlsuser user https://example.com
|
--tlsv1.0 | 告诉 curl 使用 TLS1.0 或更新版本。
例子: curl --tlsv1.0 https://example.com
|
--tlsv1.1 | 告诉 curl 使用 TLS1.1 或更新版本。
例子: curl --tlsv1.1 https://example.com
|
--tlsv1.2 | 告诉 curl 使用 TLS1.2 或更新版本。
例子: curl --tlsv1.2 https://example.com
|
--tlsv1.3 | 告诉 curl 使用 TLS1.3 或更新版本。
例子: curl --tlsv1.3 https://example.com
|
-1, --tlsv1 | 指定 curl 应至少使用 1.x 版本的 TLS。 例子: curl --tlsv1 https://example.com
|
--tr-encoding | 请求压缩的传输编码响应。 例子: curl --tr-encoding https://example.com
|
--trace-ascii <
file>
| 启用到文件的完整跟踪转储。消除十六进制部分并仅显示 ASCII。 例子: curl --trace-ascii log.txt https://example.com
|
--trace-time | 需要在每个跟踪或详细行上添加时间戳。
例子: curl --trace-time --trace-ascii output https://example.com
|
--trace <
file>
| 启用到文件的完整跟踪转储。
例子: curl --trace log.txt https://example.com
|
--unix-socket <
path>
| 指定 Unix 套接字路径。
例子: curl --unix-socket socket-path https://example.com
|
-T, --upload-file <
file>
| 将文件上传到 URL。 Linux curl命令用法示例: curl -T "img[1-1000].png" ftp://ftp.example.com/ |
--url <
url>
| 提供要获取的 URL。
例子: curl --url https://example.com
|
-B, --use-ascii | 启用 ASCII 传输。
例子: curl -B ftp://example.com/README
|
-A, --user-agent <
name>
| 指定用户代理名称。
例子: curl -A "Agent 007" https://example.com
|
-u, --user <
user:password>
| 提供用于身份验证的用户名和密码。
例子: curl -u user:secret https://example.com
|
-v, --verbose | 告诉 curl 冗长。
例子: curl --verbose https://example.com
|
-V, --version | 查看已安装的 curl 和 libcurl 版本。 例子: curl --version
|
-w, --write-out <
format>
| 告诉 curl 在标准输出上显示有关已完成传输的信息。
例子: curl -w '%{http_code}\n' https://example.com
|
--xattr | 将文件元数据存储在文件属性中。 例子: curl --xattr -o storage https://example.com
|
curl --manual
在终端中执行命令。Linux curl命令使用教程结论【Linux curl命令如何使用(用法示例介绍)】Linux curl命令如何使用?阅读本教程后,你应该知道如何使用 curl 命令及其众多选项。要了解有关 curl 可以做什么的更多信息,请阅读如何使用 curl 设置或更改用户代理。
推荐阅读
- Git工作原理介绍(Git是如何工作的())
- 如何升级或降级TensorFlow(详细操作步骤介绍)
- 最容易方便系统重装的办法
- windows8镜像纯净版安装图文详细教程
- 深度系统win764位系统安装图文详细教程
- 32位win10装Win764双系统图解图文详细教程
- 最好用的一键系统重装雨林木风软件
- 32win7装64win7具体设置过程
- 本文告诉你win10 x86 x64区别