curl是常用的網(wǎng)絡(luò)調(diào)試工具解恰,特別是HTTP請(qǐng)求用它調(diào)試非常方便。
參數(shù)大綱
參數(shù) | 說明 |
---|---|
-v | 打印頭信息 |
-X | 設(shè)置請(qǐng)求方法挟纱,其中POST方法經(jīng)常與-d搭配使用 |
-d | 設(shè)置POST請(qǐng)求體-d 'type=0?enable=1' |
-o | 下載文件腐宋,如:-o 1.txt。若指定-v -o /dev/null可以值看請(qǐng)求過程方便調(diào)試 |
-L | 自動(dòng)處理重定向 |
-H | 設(shè)置請(qǐng)求頭围苫,如-H "Content-Type: application/json"撤师,多個(gè)頭可增加多個(gè)-H參數(shù) |
-k | 忽略TSL/SSL證書檢查 |
-s | 不打印下載等細(xì)節(jié)的進(jìn)度拧揽,可以使調(diào)試內(nèi)容更清晰 |
--limit-rate | 限制帶寬 |
--resolve | 設(shè)置請(qǐng)求鏈接的IP淤袜,例如--resolve *:443:127.0.0.1,即所有連接至443端口的請(qǐng)求铡羡,都連接至127.0.0.1這臺(tái)機(jī)器 |
簡(jiǎn)單示例
- 執(zhí)行以下命令會(huì)將http://baidu.com頁(yè)面的原始內(nèi)容打印在控制臺(tái)
$ curl -X GET http://baidu.com
<html>
<meta http-equiv="refresh" content="0;url=http://www.baidu.com/">
</html>
- -X GET告訴curl執(zhí)行的是GET請(qǐng)求烦周,由于curl默認(rèn)行為是GET,因此GET請(qǐng)求的-X參數(shù)可以省略读慎,如
$ curl http://baidu.com
<html>
<meta http-equiv="refresh" content="0;url=http://www.baidu.com/">
</html>
- "http://"也可以省略夭委,省略后如
$ curl baidu.com
<html>
<meta http-equiv="refresh" content="0;url=http://www.baidu.com/">
</html>
常用參數(shù)
上面3組命令都是將http://baidu.com的頁(yè)面內(nèi)容打印在控制臺(tái),但要滿足真實(shí)場(chǎng)景的需要還遠(yuǎn)遠(yuǎn)不夠。
-v 打印詳情
使用頻率:☆☆☆☆☆
參數(shù)用途:增加-v參數(shù)后curl會(huì)將執(zhí)行過程打印在控制臺(tái)擎值,包括建立tcp連接逐抑、TSL/SSL握手、請(qǐng)求頭捆交、響應(yīng)頭等信息打印出來腐巢,可以很方便的查看請(qǐng)求細(xì)節(jié)
$ curl -v baidu.com
* Rebuilt URL to: baidu.com/
* Trying 110.242.68.66...
* TCP_NODELAY set
* Connected to baidu.com (110.242.68.66) port 80 (#0)
> GET / HTTP/1.1
> Host: baidu.com
> User-Agent: curl/7.54.0
> Accept: */*
>
< HTTP/1.1 200 OK
< Date: Wed, 27 Jul 2022 14:50:52 GMT
< Server: Apache
< Last-Modified: Tue, 12 Jan 2010 13:48:00 GMT
< ETag: "51-47cf7e6ee8400"
< Accept-Ranges: bytes
< Content-Length: 81
< Cache-Control: max-age=86400
< Expires: Thu, 28 Jul 2022 14:50:52 GMT
< Connection: Keep-Alive
< Content-Type: text/html
<
<html>
<meta http-equiv="refresh" content="0;url=http://www.baidu.com/">
</html>
* Connection #0 to host baidu.com left intact
-X 修改請(qǐng)求方法
使用頻率:☆☆☆
-X <METHOD>用于指定請(qǐng)求方法冯丙,HTTP協(xié)議規(guī)定的請(qǐng)求方法有GET、POST胃惜、PUT、DELETE鲫趁、HEAD等利虫,但該參數(shù)實(shí)際上可以并不對(duì)請(qǐng)求是否滿足HTTP協(xié)議要求。
$ curl -v -X GET baidu.com # 如前面所述GET請(qǐng)求的-X參數(shù)可省
...
< HTTP/1.1 200 OK
...
$ curl -v -X POST baidu.com # 該命令只為做演示疫剃,因?yàn)閎aidu.com這個(gè)地址并不響應(yīng)POST請(qǐng)求
...
< HTTP/1.1 200 OK
...
-o 下載文件
-o FILE
使用頻率:☆☆☆
參數(shù)用途:curl 默認(rèn)行為是將請(qǐng)求體打印在控制臺(tái)硼讽,但可以通過-o參數(shù)指定文件,即下載url到指定路徑
$ curl -o logo.png https://www.baidu.com/img/flexible/logo/pc/result.png
% Total % Received % Xferd Average Speed Time Time Time Current
Dload Upload Total Spent Left Speed
100 6617 100 6617 0 0 31318 0 --:--:-- --:--:-- --:--:-- 31360
$ file logo.png # file命令可以查看文件格式壤躲,可見已經(jīng)成功將上述logo下載至本地
logo.png: PNG image data, 202 x 66, 8-bit/color RGBA, non-interlaced
-L 跟蹤重定向
-L
使用頻率:☆☆☆
參數(shù)用途:大部分編程語(yǔ)言的網(wǎng)絡(luò)封裝庫(kù)均會(huì)自動(dòng)處理http協(xié)議的3xx重定向您炉,這對(duì)于使用這些編程語(yǔ)言的應(yīng)用不需要特別關(guān)注重定向的執(zhí)行細(xì)節(jié)。但curl作為一款調(diào)試工具棉胀,默認(rèn)情況下并不會(huì)執(zhí)行重定向請(qǐng)求,這對(duì)于調(diào)試非常有利霎挟。但它也同時(shí)提供了自動(dòng)處理重定向的方法麻掸,即增加-L參數(shù)。
$ curl -L -v -o logo.png http://mtw.so/5PRds7
> Host: mtw.so
> User-Agent: curl/7.54.0
> Accept: */*
>
< HTTP/1.1 302 Move Temporarily
< Content-Type: text/html;charset=UTF-8
< Content-Length: 0
< Connection: keep-alive
< Location: http://www.baidu.com/img/flexible/logo/pc/result.png
... !!! 以下是重定向的請(qǐng)求熬北,如果未增加-L參數(shù)到這里就結(jié)束了
* Trying 110.242.68.3...
* TCP_NODELAY set
* Connected to www.baidu.com (110.242.68.3) port 80 (#1)
> GET /img/flexible/logo/pc/result.png HTTP/1.1
> Host: www.baidu.com
> User-Agent: curl/7.54.0
> Accept: */*
>
< HTTP/1.1 200 OK
< Accept-Ranges: bytes
< Cache-Control: max-age=315360000
< Content-Length: 6617
< Content-Type: image/png
...