使用者工具

網站工具


os:linux:cure_指令

差異處

這裏顯示兩個版本的差異處。

連向這個比對檢視

os:linux:cure_指令 [2014/05/14 02:36] (目前版本)
eddie 建立
行 1: 行 1:
 +====== 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 模式下的文件上傳
 +
 +    <form action="​http://​cgi2.tky.3web.ne.jp/​~zzh/​up_file.cgi"​ enctype="​multipar/​form-data"​ method="​POST">​
 +    <input name="​upload"​ type="​file"/>​
 +    <input name="​nick"​ type="​submit"​ value="​go"/></​form>​
 +
 +這樣一個 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
os/linux/cure_指令.txt · 上一次變更: 2014/05/14 02:36 由 eddie