body curl 设置post_curl 命令详解
常用參數
常用參數分類
# 調試類-v, --verbose 輸出信息-q, --disable 在第一個參數位置設置后 .curlrc 的設置直接失效,這個參數會影響到 -K, --config -A, --user-agent -e, --referer-K, --config FILE 指定配置文件-L, --location 跟蹤重定向 (H) # CLI顯示設置-s, --silent Silent模式。不輸出任務內容-S, --show-error 顯示錯誤. 在選項 -s 中,當 curl 出現錯誤時將顯示-f, --fail 不顯示 連接失敗時HTTP錯誤信息-i, --include 顯示 response的header (H/F)-I, --head 僅顯示 響應文檔頭-l, --list-only 只列出FTP目錄的名稱 (F)-#, --progress-bar 以進度條 顯示傳輸進度 # 數據傳輸類-X, --request [GET|POST|PUT|DELETE|…] 使用指定的 http method 例如 -X POST-H, --header 設定 request里的header 例如 -H "Content-Type: application/json"-e, --referer 設定 referer (H)-d, --data 設定 http body 默認使用 content-type application/x-www-form-urlencoded (H) --data-raw ASCII 編碼 HTTP POST 數據 (H) --data-binary binary 編碼 HTTP POST 數據 (H) --data-urlencode url 編碼 HTTP POST 數據 (H)-G, --get 使用 HTTP GET 方法發送 -d 數據 (H)-F, --form 模擬 HTTP 表單數據提交 multipart POST (H) --form-string 模擬 HTTP 表單數據提交 (H)-u, --user 使用帳戶,密碼 例如 admin:password-b, --cookie cookie 文件 (H)-j, --junk-session-cookies 讀取文件中但忽略會話cookie (H)-A, --user-agent user-agent設置 (H) # 傳輸設置-C, --continue-at OFFSET 斷點續轉-x, --proxy [PROTOCOL://]HOST[:PORT] 在指定的端口上使用代理-U, --proxy-user USER[:PASSWORD] 代理用戶名及密碼 # 文件操作-T, --upload-file 上傳文件-a, --append 添加要上傳的文件 (F/SFTP) # 輸出設置-o, --output 將輸出寫入文件,而非 stdout-O, --remote-name 將輸出寫入遠程文件-D, --dump-header 將頭信息寫入指定的文件-c, --cookie-jar 操作結束后,要寫入 Cookies 的文件位置常用curl實例
抓取頁面內容到一個文件中
curl -o home.html http://www.sina.com.cn用 -O(大寫的),后面的url要具體到某個文件,不然抓不下來。我們還可以用正則來抓取東西
curl -O http://www.mydomain.com/linux/index.html模擬用戶登錄
# 此參數相當于設置http頭 Authorization:curl --user user:password http://blog.mydomain.com/login.php# 使用用戶名、密碼認證,此參數會覆蓋“-n”、“--netrc”和“--netrc-optional”選項模擬表單信息,模擬登錄,保存cookie信息
curl -c ./cookie_c.txt -F log=aaaa -F pwd=****** http://blog.mydomain.com/login.php模擬表單信息,模擬登錄,保存頭信息
curl -D ./cookie_D.txt -F log=aaaa -F pwd=****** http://blog.mydomain.com/login.php-c(小寫)產生的cookie和-D里面的cookie是不一樣的
使用cookie文件
curl -b ./cookie_c.txt http://blog.mydomain.com/wp-admin斷點續傳,-C(大寫的)
curl -C -O http://www.sina.com.cn傳送數據
最好用登錄頁面測試,因為你傳值過去后,回抓數據,你可以看到你傳值有沒有成功
curl -d log=aaaa http://blog.mydomain.com/login.php顯示抓取錯誤 -f
curl -f http://www.sina.com.cn/asdfcurl: (22) The requested URL returned error: 404curl http://www.sina.com.cn/asdf偽造來源地址,有的網站會判斷,請求來源地址-e
curl -e http://localhost http://www.sina.com.cn當我們經常用curl去搞人家東西的時候,人家會把你的IP給屏蔽掉的,這個時候,我們可以用代理
curl -x 10.10.90.83:80 -o home.html http://www.sina.com.cn比較大的東西,我們可以分段下載
curl -r 0-100 -o img.part1 http://mydomian.cn/thumb/xxx.jpg % Total % Received % Xferd Average Speed Time Time Time Current Dload Upload Total Spent Left Speed100 101 100 101 0 0 1926 0 --:--:-- --:--:-- --:--:-- 0curl -r 100-200 -o img.part2 http://mydomian.cn/thumb/xxx.jpg % Total % Received % Xferd Average Speed Time Time Time Current Dload Upload Total Spent Left Speed100 101 100 101 0 0 3498 0 --:--:-- --:--:-- --:--:-- 98kcurl -r 200- -o img.part3 http://mydomian.cn/thumb/xxx.jpg % Total % Received % Xferd Average Speed Time Time Time Current Dload Upload Total Spent Left Speed100 13515 100 13515 0 0 154k 0 --:--:-- --:--:-- --:--:-- 280kll |grep img.part用的時候,把他們cat一下就OK了,cat img.part* >img.jpg
不顯示下載進度信息 -s
curl -s -o aaa.jpg顯示下載進度條 -#
curl -# -O http://www.mydomain.com/linux/25002_3.html######################################################################## 100.0%通過ftp下載文件
curl -u 用戶名:密碼 -O http://blog.mydomain.com/demo/curtain/bbstudy_files/style.css% Total % Received % Xferd Average Speed Time Time Time CurrentDload Upload Total Spent Left Speed101 1934 101 1934 0 0 3184 0 --:--:-- --:--:-- --:--:-- 7136或者用下面的方式curl -O ftp://xukai:test@192.168.242.144:21/www/focus/enhouse/index.php % Total % Received % Xferd Average Speed Time Time Time Current Dload Upload Total Spent Left Speed100 87518 100 87518 0 0 2312k 0 --:--:-- --:--:-- --:--:-- 11.5M通過ftp上傳
curl -T xukai.php ftp://xukai:test@192.168.242.144:21/www/focus/enhouse/ % Total % Received % Xferd Average Speed Time Time Time Current Dload Upload Total Spent Left Speed100 87518 0 0 100 87518 0 2040k --:--:-- --:--:-- --:--:-- 8901k用法收集
快速用法(配合sed/awk/grep)
$curl http: //mydomain.net下載保存
$curl http://mydomain.net > index.html$curl -o index.html http://mydomain.net$curl -O http://mydomain.net/target.tar.gzGET
$curl http://www.yahoo.com/login.cgi?user=nickname&password=12345POST
$curl -d "user=nickname&password=12345" http://www.yahoo.com/login.cgiPOST 文件
$curl -F upload= $localfile -F $btn_name=$btn_value http://mydomain.net/~zzh/up_file.cgi通過代理
$curl -x 123.45.67.89:1080 -o page.html http://mydomain.net保存cookie
$curl -x 123.45.67.89:1080 -o page1.html -D cookie0001.txt http://mydomain.net使用cookie
$curl -x 123.45.67.89:1080 -o page1.html -D cookie0002.txt -b cookie0001.txt http://mydomain.net模仿瀏覽器
$curl -A "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.0)" -x123.45.67.89:1080 -o page.html -D cookie0001.txt http://mydomain.net偽造referer
$curl -A "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.0)" -x123.45.67.89:1080 -e"mail.yahoo.com" -o page.html -D cookie0001.txt http://mydomain.net高級下載功能
循環下載
$curl -O http://mydomain.net/~zzh/screen[1-10].JPG循環(匹配)下載
$curl -O http://mydomain.net/~{zzh,nick}/[001-201].JPG # >like zzh/001.JPG循環(引用)下載
$curl -o #2_#1.jpg http://mydomain.net/~{zzh,nick}/[001-201].JPG # like >001_zzh.jpg斷點續傳
$curl -c -O http://mydomain.net/~zzh/screen1.JPG分塊下載
$curl -r 0 -10240 -o "zhao.part1" http://mydomain.net/~zzh/zhao1.mp3 &\$curl -r 10241 -20480 -o "zhao.part1" http://mydomain.net/~zzh/zhao1.mp3 &\$curl -r 20481 -40960 -o "zhao.part1" http://mydomain.net/~zzh/zhao1.mp3 &\$curl -r 40961 - -o "zhao.part1" http://mydomain.net/~zzh/zhao1.mp3...$cat zhao.part* > zhao.mp3curl語法及選項
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 如果作為第一個參數無效引用
Linux curl命令詳解
掃描關注? 進入”PHP資料“
免費獲取進階
面試、文檔、視頻資源
總結
以上是生活随笔為你收集整理的body curl 设置post_curl 命令详解的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 华为M2平板打不开云课堂_能运行PC应用
- 下一篇: 备份ad_IT管理公开课——备份恢复解决