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 回答