curl命令大全


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

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. 1. curl的使用
  2. 2. curl語法及選項

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頁面的表單數據提交到服務端。提交表單時,可以使用GETPOST提交方法。

curl同樣支持表單數據提交,也可以使用GETPOST提交方法。

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請求方法

目前為止,我們使用GETPOST兩種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-TypeAuthorization請求頭:

$ curl -H 'Content-Type:application/json' -H 'Authorization: bearer eyJhbGciOiJIUzI1NiJ9' itbilu.com

 

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>

 

參數選項

curl7.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


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM