Windows安裝curl及基本命令

Windows安裝curl及基本命令

什麼是curl命令?

curl是利用URL語法在命令行方式下工作的開源文件傳輸工具。被廣泛應用在Unix、多種Linux發行版本中,並且有DOS和win32、win64下的移植版本。

在Windows下使用curl命令:

安裝:

1:進入curl官網下載合適的版本,我這裏下載的是Windows 64位的curl.

2:解壓下載的curl

3:可以給Windows增加curl命令的環境變量,增加CURL_HOME環境變量,給PATH環境變量加上%CURL_HOME%;  

4:打開cmd ,輸入 curl --help,顯示入下,就代表成功了。

 

常用curl命令:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

82

83

84

85

86

87

88

89

90

91

92

93

94

95

96

97

98

99

100

101

102

103

104

105

106

107

108

109

110

111

112

113

-a/--append 上傳文件時,附加到目標文件 

 -A/--user-agent <string>  設置用戶代理髮送給服務器 

 - anyauth   可以使用“任何”身份驗證方法 

 -b/--cookie <name=string/file> cookie字符串或文件讀取位置 

 - basic 使用HTTP基本驗證 

 -B/--use-ascii 使用ASCII /文本傳輸 

 -c/--cookie-jar <file> 操作結束後把cookie寫入到這個文件中 

 -C/--continue-at <offset>  斷點續轉 

 -d/--data <data>   HTTP POST方式傳送數據 

 --data-ascii <data>  以ascii的方式post數據 

 --data-binary <data> 以二進制的方式post數據 

 --negotiate     使用HTTP身份驗證 

 --digest        使用數字身份驗證 

 --disable-eprt  禁止使用EPRT或LPRT 

 --disable-epsv  禁止使用EPSV 

 -D/--dump-header <file> 把header信息寫入到該文件中 

 --egd-file <file> 爲隨機數據(SSL)設置EGD socket路徑 

 --tcp-nodelay   使用TCP_NODELAY選項 

 -e/--referer 來源網址 

 -E/--cert <cert[:passwd]> 客戶端證書文件和密碼 (SSL) 

 --cert-type <type> 證書文件類型 (DER/PEM/ENG) (SSL) 

 --key <key>     私鑰文件名 (SSL) 

 --key-type <type> 私鑰文件類型 (DER/PEM/ENG) (SSL) 

 --pass  <pass>  私鑰密碼 (SSL) 

 --engine <eng>  加密引擎使用 (SSL). "--engine list" for list 

 --cacert <file> CA證書 (SSL) 

 --capath <directory> CA目錄 (made using c_rehash) to verify peer against (SSL) 

 --ciphers <list>  SSL密碼 

 --compressed    要求返回是壓縮的形勢 (using deflate or gzip) 

 --connect-timeout <seconds> 設置最大請求時間 

 --create-dirs   建立本地目錄的目錄層次結構 

 --crlf          上傳是把LF轉變成CRLF 

 -f/--fail          連接失敗時不顯示http錯誤 

 --ftp-create-dirs 如果遠程目錄不存在,創建遠程目錄 

 --ftp-method [multicwd/nocwd/singlecwd] 控制CWD的使用 

 --ftp-pasv      使用 PASV/EPSV 代替端口 

 --ftp-skip-pasv-ip 使用PASV的時候,忽略該IP地址 

 --ftp-ssl       嘗試用 SSL/TLS 來進行ftp數據傳輸 

 --ftp-ssl-reqd  要求用 SSL/TLS 來進行ftp數據傳輸 

 -F/--form <name=content> 模擬http表單提交數據 

 -form-string <name=string> 模擬http表單提交數據 

 -g/--globoff 禁用網址序列和範圍使用{}和[] 

 -G/--get 以get的方式來發送數據 

 -h/--help 幫助 

 -H/--header <line>自定義頭信息傳遞給服務器 

 --ignore-content-length  忽略的HTTP頭信息的長度 

 -i/--include 輸出時包括protocol頭信息 

 -I/--head  只顯示文檔信息 

 從文件中讀取-j/--junk-session-cookies忽略會話Cookie 

 - 界面<interface>指定網絡接口/地址使用 

 - krb4 <級別>啓用與指定的安全級別krb4 

 -j/--junk-session-cookies 讀取文件進忽略session cookie 

 --interface <interface> 使用指定網絡接口/地址 

 --krb4 <level>  使用指定安全級別的krb4 

 -k/--insecure 允許不使用證書到SSL站點 

 -K/--config  指定的配置文件讀取 

 -l/--list-only 列出ftp目錄下的文件名稱 

 --limit-rate <rate> 設置傳輸速度 

 --local-port<NUM> 強制使用本地端口號 

 -m/--max-time <seconds> 設置最大傳輸時間 

 --max-redirs <num> 設置最大讀取的目錄數 

 --max-filesize <bytes> 設置最大下載的文件總量 

 -M/--manual  顯示全手動 

 -n/--netrc 從netrc文件中讀取用戶名和密碼 

 --netrc-optional 使用 .netrc 或者 URL來覆蓋-n 

 --ntlm          使用 HTTP NTLM 身份驗證 

 -N/--no-buffer 禁用緩衝輸出 

 -o/--output 把輸出寫到該文件中 

 -O/--remote-name 把輸出寫到該文件中,保留遠程文件的文件名 

 -p/--proxytunnel   使用HTTP代理 

 --proxy-anyauth 選擇任一代理身份驗證方法 

 --proxy-basic   在代理上使用基本身份驗證 

 --proxy-digest  在代理上使用數字身份驗證 

 --proxy-ntlm    在代理上使用ntlm身份驗證 

 -P/--ftp-port <address> 使用端口地址,而不是使用PASV 

 -Q/--quote <cmd>文件傳輸前,發送命令到服務器 

 -r/--range <range>檢索來自HTTP/1.1或FTP服務器字節範圍 

 --range-file 讀取(SSL)的隨機文件 

 -R/--remote-time   在本地生成文件時,保留遠程文件時間 

 --retry <num>   傳輸出現問題時,重試的次數 

 --retry-delay <seconds>  傳輸出現問題時,設置重試間隔時間 

 --retry-max-time <seconds> 傳輸出現問題時,設置最大重試時間 

 -s/--silent靜音模式。不輸出任何東西 

 -S/--show-error   顯示錯誤 

 --socks4 <host[:port]> 用socks4代理給定主機和端口 

 --socks5 <host[:port]> 用socks5代理給定主機和端口 

 --stderr <file> 

 -t/--telnet-option <OPT=val> Telnet選項設置 

 --trace <file>  對指定文件進行debug 

 --trace-ascii <file> Like --跟蹤但沒有hex輸出 

 --trace-time    跟蹤/詳細輸出時,添加時間戳 

 -T/--upload-file <file> 上傳文件 

 --url <URL>     Spet URL to work with 

 -u/--user <user[:password]>設置服務器的用戶和密碼 

 -U/--proxy-user <user[:password]>設置代理用戶名和密碼 

 -v/--verbose 

 -V/--version 顯示版本信息 

 -w/--write-out [format]什麼輸出完成後 

 -x/--proxy <host[:port]>在給定的端口上使用HTTP代理 

 -X/--request <command>指定什麼命令 

 -y/--speed-time 放棄限速所要的時間。默認爲30 

 -Y/--speed-limit 停止傳輸速度的限制,速度時間'秒 

 -z/--time-cond  傳送時間設置 

 -0/--http1.0  使用HTTP 1.0 

 -1/--tlsv1  使用TLSv1(SSL) 

 -2/--sslv2 使用SSLv2的(SSL) 

 -3/--sslv3         使用的SSLv3(SSL) 

 --3p-quote      like -Q for the source URL for 3rd party transfer 

 --3p-url        使用url,進行第三方傳送 

 --3p-user       使用用戶名和密碼,進行第三方傳送 

 -4/--ipv4   使用IP4 

 -6/--ipv6   使用IP6 

 -#/--progress-bar 用進度條顯示當前的傳送狀態

  

例子:

1

curl http://item.taobao.com/item.html?id=1264


獲得頁面的HTML數據,如圖所示。

1

curl http://item.taobao.com/item.html?id=1264 -i

  

除了獲取頁面HTML數據外,還可以查看這次訪問的HTTP頭的信息,如圖所示。

1

curl http://item.taobao.com/item.html?id=1264 -I


僅獲取HTTP頭的

1

curl http://item.taobao.com/item.html?id=1264 -v

  

獲取更詳細的信息,可以看到包括解析ip的過程都有。

1

curl http://item.taobao.com/item.html?id=1264


實際上就是在模擬form表單,該表單使用的是get方法,去掉獲取數據同上。

1

curl -I -m 10 -o /dev/null -s -w %{http_code} www.baidu.com


HTTP返回狀態碼意義:請查看此處http狀態碼大全

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章