我不能让下面的代码工作。它显示为已登录,但随后返回带有$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发布于 2012-12-07 13:18:45
还有一个事件目标字段也需要设置,帖子也需要一个不同的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调试代理来调试这样的问题,这正是我所做的。
https://stackoverflow.com/questions/13756065
复制相似问题