前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Linux 命令(136)—— curl 命令

Linux 命令(136)—— curl 命令

作者头像
恋喵大鲤鱼
发布2020-03-09 11:47:07
3.4K0
发布2020-03-09 11:47:07
举报
文章被收录于专栏:C/C++基础C/C++基础

curl 命令是一个利用 URL 规则在 Shell 终端命令行下工作的文件传输工具;它支持文件的上传和下载,所以是综合传输工具,但按传统,习惯称 curl 为下载工具。

作为一款强力工具,curl 支持包括HTTP、HTTPS、FTP 等众多协议,还支持 POST、cookies、认证、从指定偏移处下载部分文件、用户代理字符串、限速、文件大小、进度条等特征;做网页处理流程和数据检索自动化。

2.命令格式

代码语言:javascript
复制
curl [OPTIONS] [URL...]

3.选项说明

代码语言:javascript
复制
-#, --progress-bar
	显示进度条
-a, --append
	上传文件时,附加到目标文件
-A, --user-agent STRING
	设置用户代理发送给服务器
--anyauth
	可以使用“任何”身份验证方法
-b, --cookie <NAME=STRING/FILE>
	cookie 字符串或文件读取位置
--basic
	使用 HTTP 基本验证
-B, --use-ascii
	使用 ASCII 文本传输
-c, --cookie-jar FILE
	操作结束后把 cookie 写入指定文件中
-C, --continue-at OFFSET
	断点续转
-d, --data DATA
	HTTP POST 方式传送数据
--data-ascii DATA
	以 ascii 的方式 post 数据
--data-binary DATA
	以二进制的方式 post 数据
--negotiate
	使用 HTTP 身份验证
--digest
	使用数字身份验证
--disable-eprt
	禁止使用 EPRT 或 LPRT
--disable-epsv
	禁止使用 EPSV
-D, --dump-header FILE
	把 header 信息写入到指定文件中
--egd-file FILE
 	为随机数据(SSL)设置EGD socket路径
--tcp-nodelay
	使用 TCP_NODELAY 选项
-e, --referer
	来源网址
-E, --cert CERT[:PASSWD]
	客户端证书文件和密码 (SSL)
 --cert-type TYPE
 	证书文件类型 (DER/PEM/ENG) (SSL)
--key KEY
	私钥文件名 (SSL)
--key-type TYPE
	私钥文件类型 (DER/PEM/ENG) (SSL)
--pass PASS
	私钥密码 (SSL)
--engine NAME
	选择用于密码操作的OpenSSL加密引擎
--cacert FILE
	CA证书 (SSL)
--capath <directory>	CA目录 (made using c_rehash) to verify peer against (SSL)
--ciphers LIST
	SSL 密码
--compressed
	要求返回是压缩的形势 (using deflate or gzip)
--connect-timeout SECONDS
	设置最大请求时间
--create-dirs
	建立本地目录的目录层次结构
--crlf
	上传是把 LF 转变成 CRLF
-f, --fail
	连接失败时不显示 http 错误
--ftp-create-dirs
	如果远程目录不存在,创建远程目录
--ftp-method [multicwd/nocwd/singlecwd]
	控制 CWD 的使用
--ftp-pasv
	使用 PASV/EPSV 代替端口
--ftp-skip-pasv-ip
	使用 PASV 的时候,忽略该IP地址
--ftp-ssl
	尝试用 SSL/TLS 来进行 ftp 数据传输
--ftp-ssl-reqd
	要求用 SSL/TLS 来进行 ftp 数据传输
-F, --form NAME=CONTENT
	模拟 http 表单提交数据
--form-string NAME=STRING
	模拟 http 表单提交数据
-g, --globoff
	禁用网址序列和范围使用 {} 和 []
-G, --get
	以get的方式来发送数据
-H, --header LINE
	自定义头信息传递给服务器
--ignore-content-length
	忽略的 HTTP 头信息的长度
-i, --include
	输出时包括 protocol 头信息
-I, --head
	只显示请求头信息
-j, --junk-session-cookies
	读取文件进忽略 session cookie
--interface INTERFACE
	使用指定网络接口/地址
--krb4 LEVEL
	使用指定安全级别的 krb4
-k, --insecure
	允许不使用证书到SSL站点
-K, --config
	指定的配置文件读取
-l, --list-only
	列出ftp目录下的文件名称
--limit-rate RATE
	设置传输速度
--local-port NUM[-NUM]
	强制使用本地端口号
-m, --max-time SECONDS
	设置最大传输时间
--max-redirs NUM
	设置最大读取的目录数
--max-filesize BYTES
	设置最大下载的文件总量
-M, --manual
	显示全手动
-n, --netrc
	从 netrc 文件中读取用户名和密码
--netrc-optional
	使用 .netrc 或者 URL来覆盖 -n
--ntlm
	使用 HTTP NTLM 身份验证
-N, --no-buffer
	禁用缓冲输出
-o, --output FILE
	把输出写到指定文件中
-O, --remote-name
	把输出写到与远程文件同名的本地文件中
-p, --proxytunnel
	使用 HTTP 代理
--proxy-anyauth
	选择任一代理身份验证方法
--proxy-basic
	在代理上使用基本身份验证
--proxy-digest
	在代理上使用数字身份验证
 --proxy-ntlm
 	在代理上使用 ntlm 身份验证
-P, --ftp-port ADDRESS
	使用端口地址,而不是使用PASV
-q, --disable
	作为第一个参数,关闭 .curlrc
-Q, --quote CMD
	文件传输前,发送命令到服务器
-r/--range RANGE
	检索来自HTTP/1.1或FTP服务器字节范围
--range-file
	读取(SSL)的随机文件
-R, --remote-time
	在本地生成文件时,保留远程文件时间
--retry NUM
	传输出现问题时,重试的次数
--retry-delay SECONDS
	传输出现问题时,设置重试间隔时间
--retry-max-time SECONDS
	传输出现问题时,设置最大重试时间
-s, --silent
	静默模式。不输出任何东西
-S, --show-error
	显示错误
--socks4 HOST[:PORT]
	用 socks4 代理给定主机和端口
--socks5 HOST[:PORT]
	用 socks5 代理给定主机和端口
--stderr FILE
	将对 stderr 的所有写入重定向到指定的文件
-t, --telnet-option OPT=VAL
	Telnet 选项设置
--trace FILE
	对指定文件进行 debug
--trace-ascii FILE
	启用对所有传入和传出数据(包括描述性信息)的完整跟踪转储到给定文件。使用“-”作为文件名将输出发送到 stdout
--trace-time
	跟踪详细输出时,添加时间戳
-T, --upload-file FILE
	上传文件
--url URL
	指定要提取的 URL
-u, --user USER[:PASSWORD]
	设置服务器的用户和密码
-U, --proxy-user USER[:PASSWORD]
	设置代理用户名和密码
-w, --write-out FORMAT
	什么输出完成后
-x, --proxy HOST[:PORT]
	在给定的端口上使用HTTP代理
-X, --request COMMAND
	指定什么命令
-y, --speed-time
	放弃限速所要的时间,默认为30
-Y, --speed-limit
	停止传输速度的限制,速度时间

4.常用示例

(1)获取指定网页的数据。

代码语言:javascript
复制
curl https://github.com/dablelv/CEasyLocalLog/archive/master.zip
<html>
<head><title>301 Moved Permanently</title></head>
<body>
<center><h1>301 Moved Permanently</h1></center>
<hr><center>nginx</center>
</body>
</html>

(2)把输出写到与远程文件同名的本地文件中。

代码语言:javascript
复制
curl -O  https://github.com/jindeng/sz14.git
  % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current
                                 Dload  Upload   Total   Spent    Left  Speed
100   162  100   162    0     0    303      0 --:--:-- --:--:-- --:--:--   303

#查看文件
ls
sz14.git

(3)静默模式下载东西。

代码语言:javascript
复制
curl -s -O  https://github.com/jindeng/sz14.git

(4)访问需要授权的页面时,可通过 -u 选项提供用户名和密码进行授权。

代码语言:javascript
复制
curl -uroot  https://github.com/jindeng/sz14.git
Enter host password for user 'root':

(5)显示进度条。

代码语言:javascript
复制
curl --progress-bar  -O  https://github.com/jindeng/sz14.git
######################################################################## 100.0%

(6)只打印响应头部信息。

代码语言:javascript
复制
curl -I https://github.com/jindeng/sz14.git

通过 -I 或者 --head 可以只打印出HTTP头部信息。

(7)用 curl 进行认证。

代码语言:javascript
复制
curl -u user:pwd  https://github.com/jindeng/sz14.git

(8)限制 curl 的下载速度。

代码语言:javascript
复制
curl URL --limit-rate 50k

使用 --limit-rate 限制 curl 的下载速度,命令中用 k(千字节)和 m(兆字节)指定下载速度限制。

(9)指定可下载的最大文件大小。

代码语言:javascript
复制
curl URL --max-filesize bytes

使用 --max-filesize 指定可下载的最大文件大小,如果文件大小超出限制,命令则返回一个非 0 退出码,如果命令正常则返回 0。

(10) 用 curl 设置用户代理。

代码语言:javascript
复制
curl URL -A "Mozilla/5.0"

有些网站访问会提示只能使用 IE 浏览器来访问,这是因为这些网站设置了检查用户代理,可以使用curl把用户代理设置为IE,这样就可以访问了。使用 -A 或者 --user-agent 选项。

(11)自定义头信息传递给服务器。其他HTTP头部信息也可以使用 curl 来发送,使用 -H"头部信息" 传递多个头部信息。

代码语言:javascript
复制
curl -H "Host:man.linuxde.net" -H "accept-language:zh-cn" URL

(12)curl 设置 cookies。使用 --cookie 选项来指定 cookie,多个 cookie 使用分号分隔。

代码语言:javascript
复制
curl URL --cookie "user=root;pass=123456"

将 cookie 另存为一个文件,使用 --cookie-jar 选项。

代码语言:javascript
复制
curl URL --cookie-jar cookie_file

(13)curl 设置参照页字符串。使用 --referer 选项指定参照页字符串。

代码语言:javascript
复制
curl --referer URL1 URL2

参照页是位于 HTTP 头部中的一个字符串,用来表示用户是从哪个页面到达当前页面的,如果用户点击网页 A 中的某个连接,那么用户就会跳转到B网页,网页 B 头部的参照页字符串就包含网页 A 的 URL。

(14)断点续传。curl 能够从特定的文件偏移处继续下载,它可以通过指定一个便移量来下载部分文件。

代码语言:javascript
复制
curl URL/File -C OFFSET

偏移量是以字节为单位的整数,如果让 curl 自动推断出正确的续传位置使用:

代码语言:javascript
复制
curl -C - URL

(15)抓取页面内容到一个文件中。

代码语言:javascript
复制
curl -o git.html https://github.com/jindeng/sz14.git

(16)连接失败时不显示 http 错误。

代码语言:javascript
复制
curl -f https://github.com/jindeng/sz14.git
<html>
<head><title>301 Moved Permanently</title></head>
<body bgcolor="white">
<center><h1>301 Moved Permanently</h1></center>
<hr><center>nginx</center>
</body>
</html>

(17)通过 ftp 上传。

代码语言:javascript
复制
curl -T test.sql ftp://用户名:密码@ip:port/demo/curtain/bbstudy_files/ 

(18)通过 ftp下载。

代码语言:javascript
复制
curl -u 用户名:密码 -O URL

参考文献

[1] curl(1) manual [2] CSDN.【Linux】一步一步学Linux——curl命令(193)

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2020-03-09 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 2.命令格式
  • 3.选项说明
  • 4.常用示例
  • 参考文献
相关产品与服务
多因子身份认证
多因子身份认证(Multi-factor Authentication Service,MFAS)的目的是建立一个多层次的防御体系,通过结合两种或三种认证因子(基于记忆的/基于持有物的/基于生物特征的认证因子)验证访问者的身份,使系统或资源更加安全。攻击者即使破解单一因子(如口令、人脸),应用的安全依然可以得到保障。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档