curl 命令行工具的使用及命令參數說明

curl
是一個開源的用於數據傳輸的命令行工具與庫,它使用URL
語法格式,支持眾多傳輸協議,包括:HTTP、HTTPS、FTP、FTPS、GOPHER、TFTP、SCP、SFTP、SMB、TELNET、DICT、LDAP、LDAPS、FILE、IMAP、SMTP、POP3、RTSP和RTMP。curl
庫提供了很多強大的功能,你可以利用它來進行HTTP/HTTPS請求、上傳/下載文件等,且支持Cookie、認證、代理、限速等。
1. curl
的使用
1.1 URL訪問
訪問一個網頁時,可以使用curl
命令后加上要訪問的網址:
$ curl itbilu.com <html> <head><title>301 Moved Permanently</title></head> <body bgcolor="white"> <center><h1>301 Moved Permanently</h1></center> <hr><center>nginx/1.6.2</center> </body> </html>
如上所示,我們就看到所訪問網址的頁面源碼。
重定向跟蹤
在上面示例中,頁面使用了301重定向,這時我們可以添加-L
參數來跟蹤URL重定向:
$ curl -L itbilu.com
頁面保存
如果需要將頁面源碼保存到本地,可以使用-o
參數:
$ curl -o [文件名] itbilu.com
查看頭信息
如果需要查看訪問頁面的可以添加-i
或--include
參數:
$ curl -i itbilu.com
添加-i
參數后,頁面響應頭會和頁面源碼(響應體)一塊返回。如果只想查看響應頭,可以使用-I
或--head
參數:
$ curl -I itbilu.com HTTP/1.1 301 Moved Permanently Server: nginx/1.6.2 Date: Sun, 25 Jun 2017 02:03:45 GMT Content-Type: text/html Content-Length: 184 Connection: keep-alive Location: https://itbilu.com/
1.2 表單提交
通過Form
表單,可以將Web頁面的表單數據提交到服務端。提交表單時,可以使用GET
或POST
提交方法。
curl
同樣支持表單數據提交,也可以使用GET
或POST
提交方法。
GET
數據提交
當全用GET
表單數據提交時,提交數據會被附加到請求URL的后面。類型如下:
$ curl '//itbilu.com/?keyword=linux&page=3'
使用curl
進行GET
數據提交時,也可以直接把提交數據添加到URL后面:
curl https://itbilu.com/?keyword=linux&page=3
POST
數據提交
curl
使用POST
提交表單數據時,除了-X
參數指定請求方法外,還要使用--data
參數添加提交數據:
$ curl -X POST --data 'keyword=linux' itbilu.com
1.3 其它HTTP請求方法
目前為止,我們使用GET
和POST
兩種HTTP請求。curl
支持所有HTTP請求方法,只要通過-X
參數指定即可。
如,使用DELETE
請求:
$ curl -X DELETE itbilu.com/examlple.html
使用PUT
請求,並指定請求數據:
$ curl -X PUT --data 'keyword=linux' itbilu.com
1.4 文件上傳
curl
支持文件上傳,上傳文件時使用-T
或--upload-file
參數:
$ curl -T ./index.html www.uploadhttp.com/receive.cgi
1.5 HTTPS支持
對於使用了SSL/TLS
加密的HTTPS協議,可以使用curl
直接訪問:
$ curl https://itbilu.com
如果使用的本地ssl證書
認證的HTTPS,可以通過-E
或--cert
參數指定本地證書:
$ curl -E mycert.pem https:/itbilu.com
1.6 添加請求頭
有時在進行HTTP請求時,需要自定義請求頭。在curl
中,可以通過-H
或--header
參數來指定請求頭。多次使用-H
或--header
參數可指定多個請求頭。
如,指定Content-Type
及Authorization
請求頭:
$ curl -H 'Content-Type:application/json' -H 'Authorization: bearer eyJhbGciOiJIUzI1NiJ9' itbilu.com
1.7 Cookie支持
Cookie
是一種常用的保持服務端會話信息的方法,crul
也支持使用Cookie
。
可以通過--cookie
參數指定發送請求時的Cookie
值,也可以通過-b [文件名]
來指定一個存儲了Cookie
值的本地文件:
$ curl -b stored_cookies_in_file itbilu.com
Cookie
值可能會被服務器所返回的值所修改,並應用於下次HTTP請求。這時,可以能過-c
參數指定存儲服務器返回Cookie
值的存儲文件:
$ curl -b cookies.txt -c newcookies.txt itbilu.com
除以上用法外,curl
還可以設置用戶代理(客戶端)信息、使用代理服務器、指定認證用戶名/密碼等。詳見:curl
語法及選項
curl --silent -H "Host: www.test.com" "192.168.0.1/xxx/xxx/t.php"
curl "http://www.test.com/LiveUserCount.ac " -x 127.0.0.1:1080
2. curl
語法及選項
語法
curl
語法結構如下:
curl [options...] <url>
參數選項
curl
(7.29.0
)所支持的選項(options
)參數如下:
在以下選項中,(H) 表示僅適用 HTTP/HTTPS ,(F) 表示僅適用於 FTP --anyauth 選擇 "any" 認證方法 (H) -a, --append 添加要上傳的文件 (F/SFTP) --basic 使用HTTP基礎認證(Basic Authentication)(H) --cacert FILE CA 證書,用於每次請求認證 (SSL) --capath DIR CA 證書目錄 (SSL) -E, --cert CERT[:PASSWD] 客戶端證書文件及密碼 (SSL) --cert-type TYPE 證書文件類型 (DER/PEM/ENG) (SSL) --ciphers LIST SSL 秘鑰 (SSL) --compressed 請求壓縮 (使用 deflate 或 gzip) -K, --config FILE 指定配置文件 --connect-timeout SECONDS 連接超時設置 -C, --continue-at OFFSET 斷點續轉 -b, --cookie STRING/FILE Cookies字符串或讀取Cookies的文件位置 (H) -c, --cookie-jar FILE 操作結束后,要寫入 Cookies 的文件位置 (H) --create-dirs 創建必要的本地目錄層次結構 --crlf 在上傳時將 LF 轉寫為 CRLF --crlfile FILE 從指定的文件獲得PEM格式CRL列表 -d, --data DATA HTTP POST 數據 (H) --data-ascii DATA ASCII 編碼 HTTP POST 數據 (H) --data-binary DATA binary 編碼 HTTP POST 數據 (H) --data-urlencode DATA url 編碼 HTTP POST 數據 (H) --delegation STRING GSS-API 委托權限 --digest 使用數字身份驗證 (H) --disable-eprt 禁止使用 EPRT 或 LPRT (F) --disable-epsv 禁止使用 EPSV (F) -D, --dump-header FILE 將頭信息寫入指定的文件 --egd-file FILE 為隨機數據設置EGD socket路徑(SSL) --engine ENGINGE 加密引擎 (SSL). "--engine list" 指定列表 -f, --fail 連接失敗時不顯示HTTP錯誤信息 (H) -F, --form CONTENT 模擬 HTTP 表單數據提交(multipart POST) (H) --form-string STRING 模擬 HTTP 表單數據提交 (H) --ftp-account DATA 帳戶數據提交 (F) --ftp-alternative-to-user COMMAND 指定替換 "USER [name]" 的字符串 (F) --ftp-create-dirs 如果不存在則創建遠程目錄 (F) --ftp-method [MULTICWD/NOCWD/SINGLECWD] 控制 CWD (F) --ftp-pasv 使用 PASV/EPSV 替換 PORT (F) -P, --ftp-port ADR 使用指定 PORT 及地址替換 PASV (F) --ftp-skip-pasv-ip 跳過 PASV 的IP地址 (F) --ftp-pret 在 PASV 之前發送 PRET (drftpd) (F) --ftp-ssl-ccc 在認證之后發送 CCC (F) --ftp-ssl-ccc-mode ACTIVE/PASSIVE 設置 CCC 模式 (F) --ftp-ssl-control ftp 登錄時需要 SSL/TLS (F) -G, --get 使用 HTTP GET 方法發送 -d 數據 (H) -g, --globoff 禁用的 URL 隊列 及范圍使用 {} 和 [] -H, --header LINE 要發送到服務端的自定義請求頭 (H) -I, --head 僅顯示響應文檔頭 -h, --help 顯示幫助 -0, --http1.0 使用 HTTP 1.0 (H) --ignore-content-length 忽略 HTTP Content-Length 頭 -i, --include 在輸出中包含協議頭 (H/F) -k, --insecure 允許連接到 SSL 站點,而不使用證書 (H) --interface INTERFACE 指定網絡接口/地址 -4, --ipv4 將域名解析為 IPv4 地址 -6, --ipv6 將域名解析為 IPv6 地址 -j, --junk-session-cookies 讀取文件中但忽略會話cookie (H) --keepalive-time SECONDS keepalive 包間隔 --key KEY 私鑰文件名 (SSL/SSH) --key-type TYPE 私鑰文件類型 (DER/PEM/ENG) (SSL) --krb LEVEL 啟用指定安全級別的 Kerberos (F) --libcurl FILE 命令的libcurl等價代碼 --limit-rate RATE 限制傳輸速度 -l, --list-only 只列出FTP目錄的名稱 (F) --local-port RANGE 強制使用的本地端口號 -L, --location 跟蹤重定向 (H) --location-trusted 類似 --location 並發送驗證信息到其它主機 (H) -M, --manual 顯示全手動 --mail-from FROM 從這個地址發送郵件 --mail-rcpt TO 發送郵件到這個接收人(s) --mail-auth AUTH 原始電子郵件的起始地址 --max-filesize BYTES 下載的最大文件大小 (H/F) --max-redirs NUM 最大重定向數 (H) -m, --max-time SECONDS 允許的最多傳輸時間 --metalink 處理指定的URL上的XML文件 --negotiate 使用 HTTP Negotiate 認證 (H) -n, --netrc 必須從 .netrc 文件讀取用戶名和密碼 --netrc-optional 使用 .netrc 或 URL; 將重寫 -n 參數 --netrc-file FILE 設置要使用的 netrc 文件名 -N, --no-buffer 禁用輸出流的緩存 --no-keepalive 禁用 connection 的 keepalive --no-sessionid 禁止重復使用 SSL session-ID (SSL) --noproxy 不使用代理的主機列表 --ntlm 使用 HTTP NTLM 認證 (H) -o, --output FILE 將輸出寫入文件,而非 stdout --pass PASS 傳遞給私鑰的短語 (SSL/SSH) --post301 在 301 重定向后不要切換為 GET 請求 (H) --post302 在 302 重定向后不要切換為 GET 請求 (H) --post303 在 303 重定向后不要切換為 GET 請求 (H) -#, --progress-bar 以進度條顯示傳輸進度 --proto PROTOCOLS 啟用/禁用 指定的協議 --proto-redir PROTOCOLS 在重定向上 啟用/禁用 指定的協議 -x, --proxy [PROTOCOL://]HOST[:PORT] 在指定的端口上使用代理 --proxy-anyauth 在代理上使用 "any" 認證方法 (H) --proxy-basic 在代理上使用 Basic 認證 (H) --proxy-digest 在代理上使用 Digest 認證 (H) --proxy-negotiate 在代理上使用 Negotiate 認證 (H) --proxy-ntlm 在代理上使用 NTLM 認證 (H) -U, --proxy-user USER[:PASSWORD] 代理用戶名及密碼 --proxy1.0 HOST[:PORT] 在指定的端口上使用 HTTP/1.0 代理 -p, --proxytunnel 使用HTTP代理 (用於 CONNECT) --pubkey KEY 公鑰文件名 (SSH) -Q, --quote CMD 在傳輸開始前向服務器發送命令 (F/SFTP) --random-file FILE 讀取隨機數據的文件 (SSL) -r, --range RANGE 僅檢索范圍內的字節 --raw 使用原始HTTP傳輸,而不使用編碼 (H) -e, --referer Referer URL (H) -J, --remote-header-name 從遠程文件讀取頭信息 (H) -O, --remote-name 將輸出寫入遠程文件 --remote-name-all 使用所有URL的遠程文件名 -R, --remote-time 將遠程文件的時間設置在本地輸出上 -X, --request COMMAND 使用指定的請求命令 --resolve HOST:PORT:ADDRESS 將 HOST:PORT 強制解析到 ADDRESS --retry NUM 出現問題時的重試次數 --retry-delay SECONDS 重試時的延時時長 --retry-max-time SECONDS 僅在指定時間段內重試 -S, --show-error 顯示錯誤. 在選項 -s 中,當 curl 出現錯誤時將顯示 -s, --silent Silent模式。不輸出任務內容 --socks4 HOST[:PORT] 在指定的 host + port 上使用 SOCKS4 代理 --socks4a HOST[:PORT] 在指定的 host + port 上使用 SOCKSa 代理 --socks5 HOST[:PORT] 在指定的 host + port 上使用 SOCKS5 代理 --socks5-hostname HOST[:PORT] SOCKS5 代理,指定用戶名、密碼 --socks5-gssapi-service NAME 為gssapi使用SOCKS5代理服務名稱 --socks5-gssapi-nec 與NEC Socks5服務器兼容 -Y, --speed-limit RATE 在指定限速時間之后停止傳輸 -y, --speed-time SECONDS 指定時間之后觸發限速. 默認 30 --ssl 嘗試 SSL/TLS (FTP, IMAP, POP3, SMTP) --ssl-reqd 需要 SSL/TLS (FTP, IMAP, POP3, SMTP) -2, --sslv2 使用 SSLv2 (SSL) -3, --sslv3 使用 SSLv3 (SSL) --ssl-allow-beast 允許的安全漏洞,提高互操作性(SSL) --stderr FILE 重定向 stderr 的文件位置. - means stdout --tcp-nodelay 使用 TCP_NODELAY 選項 -t, --telnet-option OPT=VAL 設置 telnet 選項 --tftp-blksize VALUE 設備 TFTP BLKSIZE 選項 (必須 >512) -z, --time-cond TIME 基於時間條件的傳輸 -1, --tlsv1 使用 => TLSv1 (SSL) --tlsv1.0 使用 TLSv1.0 (SSL) --tlsv1.1 使用 TLSv1.1 (SSL) --tlsv1.2 使用 TLSv1.2 (SSL) --trace FILE 將 debug 信息寫入指定的文件 --trace-ascii FILE 類似 --trace 但使用16進度輸出 --trace-time 向 trace/verbose 輸出添加時間戳 --tr-encoding 請求壓縮傳輸編碼 (H) -T, --upload-file FILE 將文件傳輸(上傳)到指定位置 --url URL 指定所使用的 URL -B, --use-ascii 使用 ASCII/text 傳輸 -u, --user USER[:PASSWORD] 指定服務器認證用戶名、密碼 --tlsuser USER TLS 用戶名 --tlspassword STRING TLS 密碼 --tlsauthtype STRING TLS 認證類型 (默認 SRP) --unix-socket FILE 通過這個 UNIX socket 域連接 -A, --user-agent STRING 要發送到服務器的 User-Agent (H) -v, --verbose 顯示詳細操作信息 -V, --version 顯示版本號並退出 -w, --write-out FORMAT 完成后輸出什么 --xattr 將元數據存儲在擴展文件屬性中 -q .curlrc 如果作為第一個參數無效
轉載:https://itbilu.com/linux/man/4yZ9qH_7X.html