我正在开发一个程序,该程序将登录网站并获取某些数据。但是,我在发布登录参数和处理 cookie 时遇到了麻烦,因为每次我看到一个页面显示“您已注销或会话已过期”。很明显,我在发布参数或处理 cookie 时做错了,但不知道是哪个。我已经为此工作了一段时间,只是无法理解为什么它不能正常工作。
void Login2(string username, string password)
{
string pageSource;
string formUrl = "https://forUrl.com";
string formParams = string.Format("login={0}&sslProt={1}&pwd={2}&gru={3}", username, "", password, "115237091");
string cookieHeader;
HttpWebRequest req = (HttpWebRequest)WebRequest.Create(formUrl);
req.AllowAutoRedirect = false;
req.ContentType = "application/x-www-form-urlencoded";
req.Method = "POST";
byte[] bytes = System.Text.Encoding.ASCII.GetBytes(formParams);
req.ContentLength = bytes.Length;
using (Stream os = req.GetRequestStream())
{
os.Write(bytes, 0, bytes.Length);
}
HttpWebResponse resp = (HttpWebResponse)req.GetResponse();
cookieHeader = resp.Headers["Set-cookie"];
string getUrl = "https://Urlbehindform.com";
HttpWebRequest getRequest = (HttpWebRequest)WebRequest.Create(getUrl);
getRequest.Method = "GET";
getRequest.AllowAutoRedirect = false;
getRequest.Headers.Add("Cookie", cookieHeader);
HttpWebResponse getResponse = (HttpWebResponse)getRequest.GetResponse();
using (StreamReader sr = new StreamReader(getResponse.GetResponseStream()))
{
pageSource = sr.ReadToEnd();
}
Response.Redirect(getUrl);
}
我在执行 POST 时获取 cookie,并在执行 GET 时将其发回,但由于某种原因,这似乎不起作用。起初我以为是参数,但在使用 Tamper Data 和 Firefox 进一步查看问题后,登录参数似乎工作正常。任何帮助都会很棒,因为我已经为此工作了一段时间并且无法理解它。谢谢!
更新:
在尝试了一些建议后,我仍然无法让它发挥作用。然而,在深入研究 Data Tamper 后,似乎有一个带有登录参数的 POST,然后是一个 GET 到另一个页面,最后是 GET 到登录页面之后的页面(我试图去的那个) . 经过进一步调试后,我实际上发现我的登录 POST 没有像我想象的那样工作,因为响应头位置显示“/cv/scripts/A028/eng/logErr.asp”。这意味着我的其余代码可能一直都很好,因为 POST 没有给我一个有效的登录名。关于为什么我总是得到登录错误页面的任何建议?一如既往地感谢您的帮助。
更新:
在进一步使用 Tamper Data 之后,似乎我无法成功登录的原因是为了成功 POST 参数,需要已经获得 cookie。我该怎么做呢?