cURL是什麼?
cURL是一個利用URL語法在命令行下工作的文件傳輸工具,1997年首次發行。它支持文件上傳和下載,所以是綜合傳輸工具,但按傳統,習慣稱cURL爲下載工具。cURL還包含了用於程序開發的libcurl。
cURL能做什麼?
cURL支持的通信協議有FTP、FTPS、HTTP、HTTPS、TFTP、SFTP、Gopher、SCP、Telnet、DICT、FILE、LDAP、LDAPS、IMAP、POP3、SMTP和RTSP。
curl還支持SSL認證、HTTP POST、HTTP PUT、FTP上傳, HTTP form based upload、proxies、HTTP/2、cookies、用戶名+密碼認證(Basic, Plain, Digest, CRAM-MD5, NTLM, Negotiate and Kerberos)、file transfer resume、proxy tunneling。
其他的看不看的懂,我不關心,重要的是標紅色的內容。比如我們項目真實使用過的例子:
用cURL下載所需文件,然後驗證文件的有效性,然後做一些我們需要的操作。
cURL如何使用?
第1步:驗證客戶端是否可運行curl命令
以上爲不可識別命令,可查看是否將對應目錄()加入了環境,如path中存在,可執行第2步。
第二步:將https://download.csdn.net/download/bydbya/12374274壓縮包中bin目錄下的三個文件複製到C:\Windows\System32目錄下面。
繼續驗證curl命令是否可用,如下圖:
出現以上則代表可用。
查看其版本:curl -V 注意是大V.
顯示如下:
第三步:通過curl -help來學習相關參數使用
第四步:實例指南(需要注意大小寫)本示例已在生產環境中做日常維護使用。
下載使用:
curl -O 需要下載文件的URL地址
根據參數配合後臺代碼進行操作:
curl -d "變量名稱=變量值" 請求的URL地址
對應的後臺代碼需要使用變量名稱進行獲取,然後根據客戶端不同的請求參數來做不同的動作。
其他參數及作用
在以下選項中,(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 如果作爲第一個參數無效