天天看點

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 如果作為第一個參數無效