我正在开发一个程序,该程序将登录网站并获取某些数据。但是,我在发布登录参数和处理 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。我该怎么做呢?