C # HttpWebRequest веб-сайт войти - PullRequest
       19

C # HttpWebRequest веб-сайт войти

3 голосов
/ 26 августа 2011

Я пытаюсь переключиться с веб-браузера на http-запросы для автоматизации задач на скорость. С помощью этой функции я могу публиковать данные и получать страницу входа в систему, но файлы cookie не возвращаются и не добавляются в список файлов cookie, поэтому вошедший в систему сеанс не передается следующему запросу.

    //an example call        
    test("http://websitename.com/loginpage.php", "username=foo&password=123456");

    private string test(string url, string data)
    {
        string responseFromServer;

        byte[] byteArray;

        Stream dataStream;

        HttpWebRequest request;

        HttpWebResponse response;

        StreamReader reader;


        responseFromServer = string.Empty;

        try
        {
            request = WebRequest.Create(url) as HttpWebRequest;
            request.Method = "POST";
            request.KeepAlive = true;
            request.ContentType = "application/x-www-form-urlencoded";

            byteArray = Encoding.UTF8.GetBytes(data);
            request.ContentLength = byteArray.Length;

            request.CookieContainer = new CookieContainer();

            foreach(Cookie a in cookies)
                request.CookieContainer.Add(a);

            dataStream = request.GetRequestStream();
            dataStream.Write(byteArray, 0, byteArray.Length);
            dataStream.Close();

            response = request.GetResponse() as HttpWebResponse;

            foreach(Cookie a in response.Cookies)
                cookies.Add(a);

            dataStream = response.GetResponseStream();
            reader = new StreamReader(dataStream);
            responseFromServer = reader.ReadToEnd();

            reader.Close();
            dataStream.Close();
            response.Close();
        }
        catch (Exception x)
        {
            x.ToString();
        }

        return responseFromServer;
    }

Как мне сохранить его в системе?

Ответы [ 2 ]

9 голосов
/ 16 июля 2012

Это окончательный ответ:

string url = "http://www.ABC/MemberShip/Login.aspx";// HttpContext.Current.Request.Url.AbsoluteUri.ToString().Replace("AutoLogin", "Login");

CookieContainer myCookieContainer = new CookieContainer();
HttpWebRequest request = WebRequest.Create(url) as HttpWebRequest;
request.CookieContainer = myCookieContainer;
request.Method = "GET";
request.KeepAlive = false;

HttpWebResponse response = request.GetResponse() as HttpWebResponse;

System.IO.Stream responseStream = response.GetResponseStream();
System.IO.StreamReader reader = new System.IO.StreamReader(responseStream, Encoding.UTF8);
string srcString = reader.ReadToEnd();

// get the page ViewState                
string viewStateFlag = "id=\"__VIEWSTATE\" value=\"";
int i = srcString.IndexOf(viewStateFlag) + viewStateFlag.Length;
int j = srcString.IndexOf("\"", i);
string viewState = srcString.Substring(i, j - i);

// get page EventValidation                
string eventValidationFlag = "id=\"__EVENTVALIDATION\" value=\"";
i = srcString.IndexOf(eventValidationFlag) + eventValidationFlag.Length;
j = srcString.IndexOf("\"", i);
string eventValidation = srcString.Substring(i, j - i);

string submitButton = "LoginButton";

// UserName and Password
string userName = "userid";
string password = "password";
// Convert the text into the url encoding string
viewState = System.Web.HttpUtility.UrlEncode(viewState);
eventValidation = System.Web.HttpUtility.UrlEncode(eventValidation);
submitButton = System.Web.HttpUtility.UrlEncode(submitButton);

// Concat the string data which will be submit
string formatString =
         "txtUserName={0}&txtPassword={1}&btnSignIn={2}&__VIEWSTATE={3}&__EVENTVALIDATION={4}";
string postString =
         string.Format(formatString, userName, password, submitButton, viewState, eventValidation);

// Convert the submit string data into the byte array
byte[] postData = Encoding.ASCII.GetBytes(postString);

// Set the request parameters
request = WebRequest.Create(url) as HttpWebRequest;
request.Method = "POST";
request.Referer = url;
request.KeepAlive = false;
request.UserAgent = "Mozilla/4.0 (compatible; MSIE 8.0; Windows NT 6.1; WOW64; Trident/4.0; SLCC2; .NET CLR 2.0.50727; .NET CLR 3.5.30729; .NET CLR 3.0.30729; Media Center PC 6.0; InfoPath.2; CIBA)";
request.ContentType = "application/x-www-form-urlencoded";
request.CookieContainer = myCookieContainer;
System.Net.Cookie ck = new System.Net.Cookie("TestCookie1", "Value of test cookie");
ck.Domain = request.RequestUri.Host;
request.CookieContainer.Add(ck);
request.CookieContainer.Add(response.Cookies);

request.ContentLength = postData.Length;

// Submit the request data
System.IO.Stream outputStream = request.GetRequestStream();
request.AllowAutoRedirect = true;
outputStream.Write(postData, 0, postData.Length);
outputStream.Close();


// Get the return data
response = request.GetResponse() as HttpWebResponse;
responseStream = response.GetResponseStream();
reader = new System.IO.StreamReader(responseStream, Encoding.UTF8);
srcString = reader.ReadToEnd();
Response.Write(srcString);
Response.End();
1 голос
/ 26 августа 2011

В этом сообщении, похоже, есть ответ с положительным подсчетом голосов: C # сохранить идентификатор сеанса через httpwebrequest

Создайте экземпляр CookieContainer в своем первом запросе к серверу, и вместо создания нового для вашего следующего запроса повторно используйте этот экземпляр.

...