====== curl 指令用法 ====== http://evelynnote.blogspot.tw/2011/03/curl.html curl 是 Linux 下一個很強大的 http 命令列工具 1) 取得網頁內容,螢幕輸出 $ curl http://www.linuxidc.com 2) -o: 取得網頁內容,檔案輸出 $ curl -o page.html http://www.linuxidc.com 3) -x: 指定 http 使用的 proxy $ curl -x 123.45.67.89:1080 -o page.html http://www.linuxidc.com 4) -D: 把 http response 裡面的 cookie 資訊另存新檔 $ curl -x 123.45.67.89:1080 -o page.html -D cookie0001.txt http://www.linuxidc.com 5)-b: 把 cookie 資訊加到 http request 裡 $ curl -x 123.45.67.89:1080 -o page1.html -D cookie0002.txt -b cookie0001.txt http://www.linuxidc.com 6)-A: 設定瀏覽器資訊 #Windows 2000上的 IE6.0 $ curl -A "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.0)" -x 123.45.67.89:1080 -o page.html -D cookie0001.txt http://www.linuxidc.com # Linux Netscape 4.73 $ curl -A "Mozilla/4.73 [en] (X11; U; Linux 2.2; 15 i686" -x 123.45.67.89:1080 -o page.html -D cookie0001.txt http://www.linuxidc.com 7)-e: 設定 referrer 另外一個伺服器端常用的限制方法,就是檢查 http 訪問的 referer。比如你先訪問首頁,再訪問裡面所指定的下載頁,這第二次訪問的 referer 位址就是第一次訪問成功後的頁面位址。這樣,伺服器端只要發現對下載頁面某次訪問的 referer 位址不是首頁的位址,就可以斷定那是個盜連了 $ curl -A "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.0)" -x 123.45.67.89:1080 -e "mail.linuxidc.com" -o page.html -D cookie0001.txt http://www.linuxidc.com 8)-O: 使用伺服器上的檔案名,存在本地 $ curl -O http://cgi2.tky.3web.ne.jp/~zzh/screen1.JPG 9)可使用 Regular Expression 抓取所有 match 的檔案,指定 match 的群組內容為新檔名 $ curl -O http://cgi2.tky.3web.ne.jp/~zzh/screen[1-10].JPG $ curl -o #2-#1.jpg http://cgi2.tky.3web.ne.jp/~{zzh,nick}/[001-201].JPG 原來: ~zzh/001.JPG -> 下載後:001-zzh.JPG 原來: ~nick/001.JPG -> 下載後:001-nick.JPG 10)-c: 續傳 (只能用在原本是 curl 傳輸的檔案) $ curl -c -O http://cgi2.tky.3wb.ne.jp/~zzh/screen1.JPG 11) -r: 分塊下載 $ curl -r 0-10240 -o "zhao.part1" http:/cgi2.tky.3web.ne.jp/~zzh/zhao1.mp3 &\ $ curl -r 10241-20480 -o "zhao.part1" http:/cgi2.tky.3web.ne.jp/~zzh/zhao1.mp3 &\ $ curl -r 20481-40960 -o "zhao.part1" http:/cgi2.tky.3web.ne.jp/~zzh/zhao1.mp3 &\ $ curl -r 40961- -o "zhao.part1" http:/cgi2.tky.3web.ne.jp/~zzh/zhao1.mp3 Linux用 cat zhao.part* > zhao.mp3合併 Windows用copy /b 合併 12) -u: 指定 FTP 帳號密碼 $ curl -u name:passwd ftp://ip:port/path/file $ curl ftp://name:passwd@ip:port/path/file 13) -T: 上傳檔案 $ curl -T localfile -u name:passwd ftp://upload_site:port/path/ $ curl -T localfile http://cgi2.tky.3web.ne.jp/~zzh/abc.cgi (注意這時候使用的協定是 HTTP 的 PUT method) 14) Http GET 與 POST 模式 GET 模式什麼 option 都不用,只需要把變數寫在 url 裡面就可以了比如: $ curl http://www.linuxidc.com/login.cgi?user=nickwolfe&password=12345 而 POST 模式的 option 則是 -d $ curl -d "user=nickwolfe&password=12345" http://www.linuxidc.com/login.cgi 到底該用 GET 模式還是 POST 模式,要看對面伺服器的程式設定。比如 POST 模式下的文件上傳
這樣一個 HTTP 表單,我們要用 curl 進行模擬,就該是這樣的語法: $ curl -F upload=@localfile -F nick=go http://cgi2.tky.3web.ne.jp/~zzh/up_file.cgi 15) https 使用本地認證 $ curl -E localcert.pem https://remote_server 16) 通過 dict 協定去查字典 $ curl dict://dict.org/d:computer