3

次のコードを動作させることができません。ログインしているように見えますが、$responseを含むログインページを返します。ポストバックと関係があると思いますか?それを回避する方法はありますか?ありがとう!

$login = Invoke-WebRequest -Uri 'http://www.sqlpass.org/UserLogin.aspx' -SessionVariable sqlpass
$login.Forms[0].Fields["txtUsername_14615"] = 'myuser'
$login.Forms[0].Fields["txtPassword_14615"] = 'mypass'
$response = Invoke-WebRequest -Uri 'http://www.sqlpass.org/UserLogin.aspx' -WebSession $sqlpass -Method POST -Body $login
4

1 に答える 1

2

設定する必要のあるイベントターゲットフィールドがあります。また、POSTには別のURLが必要です。以下のソリューションをテストしたところ、機能します。

$login = Invoke-WebRequest -Uri 'http://www.sqlpass.org/UserLogin.aspx' -SessionVariable sqlpass
$form = $login.Forms[0]
$form.Fields["__EVENTTARGET"] = "UserLogin"
$form.Fields["txtUsername_14615"] = 'myuser'
$form.Fields["txtPassword_14615"] = 'mypass'
Invoke-WebRequest -Uri 'http://www.sqlpass.org/UserLogin.aspx?returnurl=%2fdefault.aspx' -WebSession $sqlpass -Method POST -Body $form.Fields

注:補足として、FiddlerなどのWebデバッグプロキシを使用して、このような問題をデバッグできます。これはまさに私が行ったことです。

于 2012-12-07T05:18:45.330 に答える