2

我想使用凭据登录第三方网站。这是我通过stackoverflow使用的代码,但它重定向到登录页面我认为会话没有存储如何存储会话

    //The URL of the Login Form of the website
    String urlSignin = "https://www.grouprevmax.com/WebMARDSV2/RevenueCaterSuper/RevenueManager.aspx";

    //The action URL of the Login Form of the website on Submit
    String urlLogin = "https://www.grouprevmax.com/WebMARDSV2/RevenueCaterSuper/RevenueManager.aspx";

    //Initializes the Uri object of the URLs
    Uri uriSignin = new Uri(urlSignin);
    Uri uriLogin = new Uri(urlLogin);

    //Hashtable to store the form details
    Hashtable formData = new Hashtable();
    formData.Add("UTC", new Hashtable());
    formData.Add("txtUserName", new Hashtable());
    formData.Add("txtPassword", new Hashtable());

    ((Hashtable)formData["UTC"])["value"] = -330;
    ((Hashtable)formData["txtUserName"])["value"] = username;
    ((Hashtable)formData["txtPassword"])["value"] = password;

    //Initializing the data for the post action
    String postData = "";

    foreach (string name in formData.Keys)
    {
        postData += "&" + name + "=" + ((Hashtable)formData[name])["value"];
    }
    postData = postData.Substring(1);

    System.Text.ASCIIEncoding encoding = new System.Text.ASCIIEncoding();
    byte[] data = encoding.GetBytes(postData);

    HttpWebRequest webReq;
    HttpWebResponse webResp;

    //To store the cookies of the response objects to be used for the next request
    CookieContainer cookies = new CookieContainer();

    String responseString = "";

    try
    {
        //Getting response for the Signin page  
        webReq = (HttpWebRequest)WebRequest.Create(urlSignin);
        webResp = (HttpWebResponse)webReq.GetResponse();

        //Storing response cookies to be used in the next request
        cookies.Add(webResp.Cookies);

        //Storing ASPSESSION cookie that appears in the Response header Set-Cookie to be used in the next request
        string sessionCookie = webResp.Headers["Set-Cookie"];
        responseString = new StreamReader(webResp.GetResponseStream()).ReadToEnd();

        string respCookie = sessionCookie.Substring(0, sessionCookie.IndexOf(';'));
        char[] separator = { '=' };
        string[] cookieValues = respCookie.Split(separator);
        cookies.Add(new Cookie(cookieValues[0], cookieValues[1], "/", "www.grouprevmax.com"));

        //Initializing the request object for log in
        webReq = (HttpWebRequest)WebRequest.Create(urlLogin);
        webReq.Accept = "text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8";
        webReq.Referer = urlSignin;
        webReq.KeepAlive = true;
        webReq.Method = "POST";
        webReq.ContentType = "application/x-www-form-urlencoded";
        webReq.ContentLength = data.Length;
        webReq.AllowAutoRedirect = false;
        webReq.CookieContainer = cookies;
        webReq.Timeout = 30000;
        webReq.ReadWriteTimeout = 60000;



        //Get the response for the request to log in
        //PROBLEM OCCURS HERE - THE CODE DOES NOT EXECUTE FURTHER
        webReq.GetRequestStream().Write(data, 0, data.Length);
        webReq.GetRequestStream().Close();
        webResp = (HttpWebResponse)webReq.GetResponse();
        responseString = new StreamReader(webResp.GetResponseStream()).ReadToEnd();

        webResp.Close();
        return responseString;
4

2 回答 2

1

您应该可以将CookieContainer与从 收集的 cookie一起使用webResp

cookies.Add(webResp.Cookies);

您不应该处理cookie,因为您低于此。只需CookieContainer在新请求上设置就足够了。

webReq.CookieContainer = cookies;
于 2013-09-09T07:28:33.203 回答
0

在第三方网站中,他们可能会通过我们加载页面时生成的一些动态参数传递凭据。因此,在此之前使用firebugor分析该网站fiddler 并确定他们在登录时传递的参数是什么,并尝试传递这些参数。这种方法可以帮助你

于 2013-09-09T08:31:40.637 回答