Linux中的curl命令怎么用
這篇文章主要介紹了Linux中的curl命令怎么用,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。
Linux常用命令curl命令 是一個利用URL規(guī)則在命令行下工作的文件傳輸工具。它支持文件的上傳和下載,所以是綜合傳輸工具,但按傳統(tǒng),習(xí)慣稱curl為下載工具
curl
利用URL規(guī)則在命令行下工作的文件傳輸工具
補(bǔ)充說明
作為一款強(qiáng)力工具,curl支持包括HTTP、HTTPS、ftp等眾多協(xié)議,還支持POST、cookies、認(rèn)證、從指定偏移處下載部分文件、用戶代理字符串、限速、文件大小、進(jìn)度條等特征。做網(wǎng)頁處理流程和數(shù)據(jù)檢索自動化,curl可以祝一臂之力。
語法
curl(選項)(參數(shù))
選項
-a/–append | 上傳文件時,附加到目標(biāo)文件 |
-A/–user-agent | 設(shè)置用戶代理發(fā)送給服務(wù)器 |
undefinedundefined-b/–cookie | cookie字符串或文件讀取位置 |
undefinedundefined-B/–use-ascii | 使用ASCII /文本傳輸 |
undefined-c/–cookie-jar | 操作結(jié)束后把cookie寫入到這個文件中 |
undefined-C/–continue-at | 斷點續(xù)傳 |
undefined-d/–data | HTTP POST方式傳送數(shù)據(jù) |
undefined –data-ascii | 以ascii的方式post數(shù)據(jù) |
undefined –data-binary | 以二進(jìn)制的方式post數(shù)據(jù) |
undefined –negotiate | 使用HTTP身份驗證 |
undefined –digest | 使用數(shù)字身份驗證 |
undefined –disable-eprt | 禁止使用EPRT或LPRT |
undefined –disable-epsv | 禁止使用EPSV |
undefined-D/–dump-header | 把header信息寫入到該文件中 |
undefined –egd-file | 為隨機(jī)數(shù)據(jù)(SSL)設(shè)置EGD socket路徑 |
undefined –tcp-nodelay | 使用TCP_NODELAY選項 |
undefined-e/–referer | 來源網(wǎng)址 |
undefined-E/–cert cert:[passwd] | 客戶端證書文件和密碼 (SSL) |
undefined –cert-type | 證書文件類型 (DER/PEM/ENG) (SSL) |
undefinedundefined –key-type | 私鑰文件類型 (DER/PEM/ENG) (SSL) |
undefinedundefined –engine | 加密引擎使用 (SSL). “–engine list” for list |
undefinedundefined –capath | CA目錄 (made using c_rehash) to verify peer against (SSL) |
undefinedundefined –compressed | 要求返回是壓縮的形勢 (using deflate or gzip) |
undefined –connect-timeout | 設(shè)置最大請求時間 |
undefined –create-dirs | 建立本地目錄的目錄層次結(jié)構(gòu) |
undefined –crlf | 上傳是把LF轉(zhuǎn)變成CRLF |
undefined-f/–fail | 連接失敗時不顯示http錯誤 |
undefined –ftp-create-dirs | 如果遠(yuǎn)程目錄不存在,創(chuàng)建遠(yuǎn)程目錄 |
undefined –ftp-method [multicwd/nocwd/singlecwd] | 控制CWD的使用 |
undefined –ftp-pasv | 使用 PASV/EPSV 代替端口 |
undefined –ftp-skip-pasv-ip | 使用PASV的時候,忽略該IP地址 |
undefined –ftp-ssl | 嘗試用 SSL/TLS 來進(jìn)行ftp數(shù)據(jù)傳輸 |
undefined –ftp-ssl-reqd | 要求用 SSL/TLS 來進(jìn)行ftp數(shù)據(jù)傳輸 |
undefined-F/–form | 模擬http表單提交數(shù)據(jù) |
undefined –form-string | 模擬http表單提交數(shù)據(jù) |
undefined-g/–globoff | 禁用網(wǎng)址序列和范圍使用{}和[] |
undefined-G/–get | 以get的方式來發(fā)送數(shù)據(jù) |
undefined-H/–header | 自定義頭信息傳遞給服務(wù)器 |
undefined –ignore-content-length | 忽略的HTTP頭信息的長度 |
undefined-i/–include | 輸出時包括protocol頭信息 |
undefinedundefined-j/–junk-session-cookies | 讀取文件進(jìn)忽略session cookie |
undefined –interface | 使用指定網(wǎng)絡(luò)接口/地址 |
undefined –krb4 | 使用指定安全級別的krb4 |
undefined-k/–insecure | 允許不使用證書到SSL站點 |
undefined-K/–config | 指定的配置文件讀取 |
undefined-l/–list-only | 列出ftp目錄下的文件名稱 |
undefined –limit-rate | 設(shè)置傳輸速度 |
undefined –local-port | 強(qiáng)制使用本地端口號 |
undefined-m/–max-time | 設(shè)置最大傳輸時間 |
undefined –max-redirs | 設(shè)置最大讀取的目錄數(shù) |
undefined –max-filesize | 設(shè)置最大下載的文件總量 |
undefinedundefined-n/–netrc | 從netrc文件中讀取用戶名和密碼 |
undefined –netrc-optional | 使用 .netrc 或者 URL來覆蓋-n |
undefined –ntlm | 使用 HTTP NTLM 身份驗證 |
undefined-N/–no-buffer | 禁用緩沖輸出 |
undefined-o/–output | 把輸出寫到該文件中 |
undefined-O/–remote-name | 把輸出寫到該文件中,保留遠(yuǎn)程文件的文件名 |
undefined-p/–proxytunnel | 使用HTTP代理 |
undefined –proxy-anyauth | 選擇任一代理身份驗證方法 |
undefined –proxy-basic | 在代理上使用基本身份驗證 |
undefined –proxy-digest | 在代理上使用數(shù)字身份驗證 |
undefined –proxy-ntlm | 在代理上使用ntlm身份驗證 |
undefined-P/–ftp-port | 使用端口地址,而不是使用PASV |
undefined-q | 作為第一個參數(shù),關(guān)閉 .curlrc |
undefined-Q/–quote | 文件傳輸前,發(fā)送命令到服務(wù)器 |
undefined-r/–range | 檢索來自HTTP/1.1或FTP服務(wù)器字節(jié)范圍 |
undefined–range-file | 讀?。⊿SL)的隨機(jī)文件 |
undefined-R/–remote-time | 在本地生成文件時,保留遠(yuǎn)程文件時間 |
undefined –retry | 傳輸出現(xiàn)問題時,重試的次數(shù) |
undefined –retry-delay | 傳輸出現(xiàn)問題時,設(shè)置重試間隔時間 |
undefined –retry-max-time | 傳輸出現(xiàn)問題時,設(shè)置最大重試時間 |
undefined-s/–silent | 靜默模式。不輸出任何東西 |
undefinedundefined –socks4 host[:port] | 用socks4代理給定主機(jī)和端口 |
undefined –socks5 host[:port] | 用socks5代理給定主機(jī)和端口 |
undefinedundefined-t/–telnet-option | Telnet選項設(shè)置 |
undefined –trace | 對指定文件進(jìn)行debug |
undefined –trace-ascii | Like –跟蹤但沒有hex輸出 |
undefined –trace-time | 跟蹤/詳細(xì)輸出時,添加時間戳 |
undefined-T/–upload-file | 上傳文件 |
undefined –url | Spet URL to work with |
undefined-u/–user user[:password] | 設(shè)置服務(wù)器的用戶和密碼 |
undefined-U/–proxy-user user[:password] | 設(shè)置代理用戶名和密碼 |
undefined-w/–write-out [format] | 什么輸出完成后 |
undefined-x/–proxy host[:port] | 在給定的端口上使用HTTP代理 |
undefinedundefined-y/–speed-time | 放棄限速所要的時間,默認(rèn)為30 |
undefined-Y/–speed-limit | 停止傳輸速度的限制,速度時間 |
undefined
實例
文件下載
curl命令可以用來執(zhí)行下載、發(fā)送各種HTTP請求,指定HTTP頭部等操作。如果系統(tǒng)沒有curl可以使用yum install curl安裝,也可以下載安裝。curl是將下載文件輸出到stdout,將進(jìn)度信息輸出到stderr,不顯示進(jìn)度信息使用--silent選項。
curl URL --silent
這條命令是將下載文件輸出到終端,所有下載的數(shù)據(jù)都被寫入到stdout。
使用選項-O將下載的數(shù)據(jù)寫入到文件,必須使用文件的絕對地址:
curl http://example.com/text.iso --silent -O
選項-o將下載數(shù)據(jù)寫入到指定名稱的文件中,并使用--progress顯示進(jìn)度條:
curl http://example.com/test.iso -o filename.iso --progress
######################################### 100.0%
不輸出錯誤和進(jìn)度信息
-s 參數(shù)將不輸出錯誤和進(jìn)度信息。
curl -s https://www.example.com
# 上面命令一旦發(fā)生錯誤,不會顯示錯誤信息。不發(fā)生錯誤的話,會正常顯示運(yùn)行結(jié)果。
如果想讓 curl 不產(chǎn)生任何輸出,可以使用下面的命令。
curl -s -o /dev/null https://google.com
斷點續(xù)傳
curl能夠從特定的文件偏移處繼續(xù)下載,它可以通過指定一個便宜量來下載部分文件:
curl URL/File -C 偏移量
#偏移量是以字節(jié)為單位的整數(shù),如果讓curl自動推斷出正確的續(xù)傳位置使用-C -:
curl -C -URL
使用curl設(shè)置參照頁字符串
參照頁是位于HTTP頭部中的一個字符串,用來表示用戶是從哪個頁面到達(dá)當(dāng)前頁面的,如果用戶點擊網(wǎng)頁A中的某個連接,那么用戶就會跳轉(zhuǎn)到B網(wǎng)頁,網(wǎng)頁B頭部的參照頁字符串就包含網(wǎng)頁A的URL。
使用--referer選項指定參照頁字符串:
curl --referer http://www.google.com http://wangchujiang.com
用curl設(shè)置用戶代理字符串
有些網(wǎng)站訪問會提示只能使用IE瀏覽器來訪問,這是因為這些網(wǎng)站設(shè)置了檢查用戶代理,可以使用curl把用戶代理設(shè)置為IE,這樣就可以訪問了。使用--user-agent或者-A選項:
curl URL --user-agent "Mozilla/5.0"
curl URL -A "Mozilla/5.0"
其他HTTP頭部信息也可以使用curl來發(fā)送,使用-H“頭部信息” 傳遞多個頭部信息,例如:
curl -H "Host:wangchujiang.com" -H "accept-language:zh-cn" URL
curl的帶寬控制和下載配額
使用--limit-rate限制curl的下載速度:
curl URL --limit-rate 50k
命令中用k(千字節(jié))和m(兆字節(jié))指定下載速度限制。
使用--max-filesize指定可下載的最大文件大?。?/p>
curl URL --max-filesize bytes
如果文件大小超出限制,命令則返回一個非0退出碼,如果命令正常則返回0。
curl --limit-rate 200k https://example.com
# 上面命令將帶寬限制在每秒 200K 字節(jié)。
用curl進(jìn)行認(rèn)證
使用curl選項 -u 可以完成HTTP或者FTP的認(rèn)證,可以指定密碼,也可以不指定密碼在后續(xù)操作中輸入密碼:
curl -u user:pwd http://wangchujiang.com
curl -u user http://wangchujiang.com
只打印響應(yīng)頭部信息
通過-I或者-head可以只打印出HTTP頭部信息:
[root@localhost text]# curl -I http://wangchujiang.com
HTTP/1.1 200 OK
Server: nginx/1.2.5
date: Mon, 10 Dec 2012 09:24:34 GMT
Content-Type: text/html; charset=UTF-8
Connection: keep-alive
Vary: Accept-Encoding
X-Pingback: http://wangchujiang.com/xmlrpc.php
get請求
curl "http://www.wangchujiang.com" # 如果這里的URL指向的是一個文件或者一幅圖都可以直接下載到本地
curl -i "http://www.wangchujiang.com" # 顯示全部信息
curl -l "http://www.wangchujiang.com" # 只顯示頭部信息
curl -v "http://www.wangchujiang.com" # 顯示get請求全過程解析
post請求
$ curl -d "param1=value1¶m2=value2" "http://www.wangchujiang.com/login"
curl -d'login=emma&password=123' -X POST https://wangchujiang.com/login
# 或者
$ curl -d 'login=emma' -d 'password=123' -X POST https://wangchujiang.com/login
--data-urlencode 參數(shù)等同于 -d,發(fā)送 POST 請求的數(shù)據(jù)體,區(qū)別在于會自動將發(fā)送的數(shù)據(jù)進(jìn)行 URL 編碼。
curl --data-urlencode 'comment=hello world' https://wangchujiang.com/login
# 上面代碼中,發(fā)送的數(shù)據(jù)hello world之間有一個空格,需要進(jìn)行 URL 編碼。
讀取本地文本文件的數(shù)據(jù),向服務(wù)器發(fā)送
curl -d '@data.txt' https://wangchujiang.com/upload
# 讀取data.txt文件的內(nèi)容,作為數(shù)據(jù)體向服務(wù)器發(fā)送。
json格式的post請求
curl -l -H "Content-type: application/json" -X POST -d '{"phone":"13521389587","password":"test"}' http://wangchujiang.com/apis/users.json
向服務(wù)器發(fā)送 Cookie
使用--cookie "COKKIES"選項來指定cookie,多個cookie使用分號分隔:
curl http://wangchujiang.com --cookie "user=root;pass=123456"
將cookie另存為一個文件,使用--cookie-jar選項:
curl URL --cookie-jar cookie_file
-b 參數(shù)用來向服務(wù)器發(fā)送 Cookie。
curl -b 'foo=bar' https://taobao.com
# 上面命令會生成一個標(biāo)頭Cookie: foo=bar,向服務(wù)器發(fā)送一個名為foo、值為bar的 Cookie。
curl -b 'foo1=bar' -b 'foo2=baz' https://taobao.com
# 上面命令發(fā)送兩個 Cookie。
```shell
curl -b cookies.txt https://www.taobao.com
# 上面命令讀取本地文件 cookies.txt,里面是服務(wù)器設(shè)置的 Cookie(參見-c參數(shù)),將其發(fā)送到服務(wù)器。
Cookie 寫入一個文件
curl -c cookies.txt https://www.taobao.com
# 上面命令將服務(wù)器的 HTTP 回應(yīng)所設(shè)置 Cookie 寫入文本文件cookies.txt。
請求的來源
-e 參數(shù)用來設(shè)置 HTTP 的標(biāo)頭 Referer,表示請求的來源。
curl -e 'https://taobao.com?q=example' https://www.example.com
# 上面命令將Referer標(biāo)頭設(shè)為 https://taobao.com?q=example。
-H 參數(shù)可以通過直接添加標(biāo)頭 Referer,達(dá)到同樣效果。
curl -H 'Referer: https://taobao.com?q=example' https://www.example.com
上傳二進(jìn)制文件
-F 參數(shù)用來向服務(wù)器上傳二進(jìn)制文件。
curl -F 'file=@photo.png' https://taobao.com/profile
# 上面命令會給 HTTP 請求加上標(biāo)頭 Content-Type: multipart/form-data ,然后將文件photo.png作為file字段上傳。
-F 參數(shù)可以指定 MIME 類型。
curl -F 'file=@photo.png;type=image/png' https://taobao.com/profile
# 上面命令指定 MIME 類型為image/png,否則 curl 會把 MIME 類型設(shè)為 application/octet-stream。
-F 參數(shù)也可以指定文件名。
curl -F 'file=@photo.png;filename=me.png' https://taobao.com/profile
# 上面命令中,原始文件名為photo.png,但是服務(wù)器接收到的文件名為me.png。
設(shè)置請求頭
-H 參數(shù)添加 HTTP 請求的標(biāo)頭。
curl -H 'Accept-Language: en-US' https://google.com
# 上面命令添加 HTTP 標(biāo)頭 Accept-Language: en-US。
curl -H 'Accept-Language: en-US' -H 'Secret-Message: xyzzy' https://google.com
# 上面命令添加兩個 HTTP 標(biāo)頭。
curl -d '{"login": "emma", "pass": "123"}' -H 'Content-Type: application/json' https://google.com/login
# 上面命令添加 HTTP 請求的標(biāo)頭是 Content-Type: application/json,然后用 -d 參數(shù)發(fā)送 JSON 數(shù)據(jù)。
跳過 SSL 檢測
curl -k https://www.example.com
# 上面命令不會檢查服務(wù)器的 SSL 證書是否正確。
請求跟隨服務(wù)器的重定向
-L 參數(shù)會讓 HTTP 請求跟隨服務(wù)器的重定向。curl 默認(rèn)不跟隨重定向。
curl -L -d 'tweet=hi' https://api.example.com/tweet
調(diào)試參數(shù)
-v 參數(shù)輸出通信的整個過程,用于調(diào)試。
curl -v https://www.example.com
# --trace參數(shù)也可以用于調(diào)試,還會輸出原始的二進(jìn)制數(shù)據(jù)。
$ curl --trace - https://www.example.com
獲取本機(jī)外網(wǎng)ip
curl ipecho.net/plain
使用 curl 測試網(wǎng)站加載速度
命令有一個鮮為人知的選項,-w,該選項在請求結(jié)束之后打印本次請求的統(tǒng)計數(shù)據(jù)到標(biāo)準(zhǔn)輸出。
首先,我們定義控制打印行為的格式化字符串。新建文本文件 fmt.txt,并填入下面的內(nèi)容:
\n
Response Time for: %{url_effective}\n\n
DNS Lookup Time:\t\t%{time_namelookup}s\n
Redirection Time:\t\t%{time_redirect}s\n
Connection Time:\t\t%{time_connect}s\n
App Connection Time:\t\t%{time_appconnect}s\n
Pre-transfer Time:\t\t%{time_pretransfer}s\n
Start-transfer Time:\t\t%{time_starttransfer}s\n\n
Total Time:\t\t\t%{time_total}s\n
curl 提供了很多置換變量,可以在格式化字符串中通過 %{var} 的形式使用。完整的變量列表可以在 curl 的 manpage 中查看。簡單介紹一下我們使用的這幾個變量:
url_effective: 執(zhí)行完地址重定向之后的最終 URL;
time_namelookup: 從請求開始至完成名稱解析所花的時間,單位為秒,下同;
time_redirect: 執(zhí)行所有重定向所花的時間;
time_connect: 從請求開始至建立 TCP 連接所花的時間;
time_appconnect: 從請求開始至完成 SSL/SSH 握手所花的時間;
time_pretransfer: 從請求開始至服務(wù)器準(zhǔn)備傳送文件所花的時間,包含了傳送協(xié)商時間;
time_starttransfer: 從請求開始至服務(wù)器準(zhǔn)備傳送第一個字節(jié)所花的時間;
time_total: 完整耗時。
然后執(zhí)行請求,通過 @filename 指定保存了格式化字符串的文件:
$ curl -L -s -w @fmt.txt -o /dev/null http://www.google.com
輸出:
Response Time for: http://www.google.co.jp/?gfe_rd=cr&dcr=0&ei=cjIaWpTkHeiQ8QfnxYzoBA
DNS Lookup Time: 0.000038s
Redirection Time: 0.207271s
Connection Time: 0.000039s
App Connection Time: 0.000039s
Pre-transfer Time: 0.000067s
Start-transfer Time: 0.260115s
Total Time: 0.467691s
要求返回是壓縮的狀態(tài)
? curl --compressed -o- -L https://yarnpkg.com/install.sh | bash
% Total % Received % Xferd Average Speed Time Time Time Current
Dload Upload Total Spent Left Speed
100 54 100 54 0 0 42 0 0:00:01 0:00:01 --:--:-- 42
100 2341 100 2341 0 0 1202 0 0:00:01 0:00:01 --:--:-- 9289
Installing Yarn!
> Downloading tarball...
[1/2]: https://yarnpkg.com/latest.tar.gz --> /var/folders/j7/3xly5sk567s65ny5dnr__3b80000gn/T/yarn.tar.gz.XXXXXXXXXX.9hJsBsrA
% Total % Received % Xferd Average Speed Time Time Time Current
Dload Upload Total Spent Left Speed
100 57 100 57 0 0 72 0 --:--:-- --:--:-- --:--:-- 72
100 93 100 93 0 0 63 0 0:00:01 0:00:01 --:--:-- 63
100 643 100 643 0 0 248 0 0:00:02 0:00:02 --:--:-- 707
100 1215k 100 1215k 0 0 153k 0 0:00:07 0:00:07 --:--:-- 305k
[2/2]: https://yarnpkg.com/latest.tar.gz.asc --> /var/folders/j7/3xly5sk567s65ny5dnr__3b80000gn/T/yarn.tar.gz.XXXXXXXXXX.9hJsBsrA.asc
100 61 100 61 0 0 356 0 --:--:-- --:--:-- --:--:-- 356
100 97 100 97 0 0 325 0 --:--:-- --:--:-- --:--:-- 325
100 647 100 647 0 0 1283 0 --:--:-- --:--:-- --:--:-- 1283
100 832 100 832 0 0 1107 0 --:--:-- --:--:-- --:--:-- 812k
感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“Linux中的curl命令怎么用”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關(guān)注億速云行業(yè)資訊頻道,更多相關(guān)知識等著你來學(xué)習(xí)!