茫茫網海中的冷日 - 對這文章發表回應
茫茫網海中的冷日
         
茫茫網海中的冷日
發生過的事,不可能遺忘,只是想不起來而已!
 恭喜您是本站第 1672400 位訪客!  登入  | 註冊
主選單

Google 自訂搜尋

Goole 廣告

隨機相片
GoodSmile_LuskyStar x StreetFighter_00036.jpg

授權條款

使用者登入
使用者名稱:

密碼:


忘了密碼?

現在就註冊!

對這文章發表回應

發表限制: 非會員 可以發表

發表者: 冷日 發表時間: 2018/10/26 14:46:19

在PowerShell中使用curl(Invoke-WebRequest)

前言

習慣了Windows的界面模式就很難轉去命令行,甚至以命令行發家的git也湧現出各種界面tool。然而命令行真的會比界面快的多,如果你是一個碼農。

situation:接到需求分析bug,需要訪問http。那臺機器屬於product,不允許裝postman。我只能手動命令行來發請求。發現了內置的PowerShell中有curl命令。歡喜試了半天,總是命令不對,Google發現這個curl是冒名頂替的,只是一個Invoke-WebRequest的alias。參考。


PS> Get-Alias -Definition Invoke-WebRequest | Format-Table -AutoSize
commandType Name version Source
----------- ---- ------- ------
Alias curl -> Invoke-WebRequest
Alias iwr -> Invoke-WebRequest
Alias wget -> Invoke-WebRequest




Invoke-WebRequest簡單用法

1.用途

Gets content from a web page on the Internet.

獲取http web請求訪問內容

2.語法Syntax


Parameter Set: Default
Invoke-WebRequest [-Uri] [-Body ] [-Certificate ]
[-CertificateThumbprint ] [-ContentType ] [-Credential ]
[-DisableKeepAlive] [-Headers ] [-InFile ] [-MaximumRedirection ]
[-Method {Default | Get | Head | Post | Put | Delete | Trace | Options | Merge | Patch} ]
[-OutFile ] [-PassThru] [-Proxy ] [-ProxyCredential ]
[-ProxyUseDefaultCredentials] [-SessionVariable ] [-TimeoutSec ]
[-TransferEncoding {chunked | compress | deflate | gzip | identity} ] [-UseBasicParsing]
[-UseDefaultCredentials] [-UserAgent ] [-WebSession ] [ ]

3.簡單的幾個用法

3.1 Get請求


PS C:\Users\rmiao> curl -URi https://www.google.com
StatusCode : 200
StatusDescription : OK
Content :
RawContent : HTTP/1.1 200 OK
X-XSS-Protection: 1; mode=block
X-Frame-Options: SAMEORIGIN
Alt-Svc: quic=":443"; ma=2592000; v="36,35,34,33,32"
Vary: Accept-Encoding
Transfer-Encoding: chunked

會發現content內容被截斷了。想要獲取完整的content:

ps> curl https://www.google.com | Select -ExpandProperty Content

3.2添加header

-Headers @{"accept"="application/json"}

3.3指定Method

-Method Get

3.4將獲取到的content輸出到文件

-OutFile 'c:\Users\rmiao\temp\content.txt'

3.5表單提交

For example:


$R = Invoke-WebRequest http://website.com/login.aspx
$R.Forms[0].Name = "MyName"
$R.Forms[0].Password = "MyPassword"
Invoke-RestMethod http://website.com/service.aspx -Body $R

or

Invoke-RestMethod http://website.com/service.aspx -Body $R.Forms[0]

3.6內容篩選


PS C:\Users\rmiao> $R = Invoke-WebRequest -URI http://www.bing.com?q=how+many+feet+in+a+mile
PS C:\Users\rmiao> $R.AllElements | where {$_.innerhtml -like "*=*"} | Sort { $_.InnerHtml.Length } | Select InnerText -
First 5
innerText
---------
=
1
Next
=

3.7一個登陸示例


#發送一個登陸請求,聲明一個sessionVariable 參數為fb, 將結果保存在$R
#這個變量FB就是header.cookie等集合
PS C:\Users\rmiao> $R=curl http://www.Facebook.com/login.php -SessionVariable fb
PS C:\Users\rmiao> $FB
Headers : {}
Cookies : system.Net.CookieContainer
UseDefaultCredentials : False
Credentials :
Certificates :
UserAgent : Mozilla/5.0 (Windows NT; Windows NT 6.3; en-US) WindowsPowerShell/4.0
Proxy :
MaximumRedirection : -1
#將response響應結果中的第一個form屬性賦值給變量Form
PS C:\Users\rmiao> $Form=$R.Forms[0]
PS C:\Users\rmiao> $Form.fields
Key Value
--- -----
lsd AVqQqrLW
display
enable_profile_selector
isprivate
legacy_return 0
profile_selector_ids
return_session
skip_api_login
signed_next
trynum 1
u_0_0
u_0_1
lgnrnd 214945_qGeg
lgnjs n
email
pass
persistent
default_persistent 1
# 查看form
PS C:\Users\rmiao> $Form | Format-List
Id : login_form
Method : post
Action : /login.php?login_attempt=1&lwv=100
Fields : {[lsd, AVqQqrLW], [display, ], [enable_profile_selector, ], [isprivate, ]...}
#查看屬性
$Form.fields
#設置賬號密碼
$Form.Fields["email"] = "[email protected]"
$Form.Fields["pass"] = "[email protected]"
#發送請求並保存結果為$R
$R=Invoke-WebRequest -Uri ("https://www.facebook.com" + $Form.Action) -WebSession $FB -Method POST -Body $Form.Fields
#查看結果
PS C:\Users\rmiao> $R.StatusDescription
OK

雖然沒有curl那麽主流,但一樣可以成為http訪問的一個選擇。

參考

https://technet.Microsoft.com/en-us/library/hh849901.aspx


原文出處:在PowerShell中使用curl(Invoke-WebRequest) - IT閱讀
內容圖示
url email imgsrc image code quote
樣本
bold italic underline linethrough   












 [詳情...]
validation picture

注意事項:
預覽不需輸入認證碼,僅真正發送文章時才會檢查驗證碼。
認證碼有效期10分鐘,若輸入資料超過10分鐘,請您備份內容後,重新整理本頁並貼回您的內容,再輸入驗證碼送出。

選項

Powered by XOOPS 2.0 © 2001-2008 The XOOPS Project|