记住使用Web请求进行身份验

时间:2011-12-06 20:51:25

标签: c# authentication httpwebrequest

我正在制作一个程序,从需要身份验证的站点获取数据。我在控制台中制作程序,所以我不能使用控件。

我可以将用户数据发送到登录表单并获取欢迎屏幕的信息。但当我发送另一个请求时,该网站忘记了我曾登录过。 我读到我必须以某种方式启用cookie,但我还没有解决它。

这是我的代码:

public string GetResponse()
{
    // Build a string containing all the parameters
    string Parameters = string.Empty;
    foreach (string p in theQueryData)
    {
        Parameters += string.Format("&{0}", p);
    }

    if (Parameters.Length > 0)
        Parameters = Parameters.Substring(1);

    // Create a request using a URL that can receive a post. 
    HttpWebRequest request = (HttpWebRequest)WebRequest.Create(this.url);

    // Set the Method property of the request to POST.
    request.Method = this.method;
    // Create POST data and convert it to a byte array.
    string postData = Parameters;
    byte[] byteArray = Encoding.UTF8.GetBytes(postData);
    // Set the ContentType property of the WebRequest.
    request.ContentType = "application/x-www-form-urlencoded";
    // Set the ContentLength property of the WebRequest.
    request.ContentLength = byteArray.Length;
    // Get the request stream.
    Stream dataStream = request.GetRequestStream();
    // Write the data to the request stream.
    dataStream.Write(byteArray, 0, byteArray.Length);
    // Close the Stream object.
    dataStream.Close();
    // Get the response.
    WebResponse response = request.GetResponse();
    // Get the stream containing content returned by the server.
    dataStream = response.GetResponseStream();
    // Open the stream using a StreamReader for easy access.
    StreamReader reader = new StreamReader(dataStream);
    // Read the content.
    string responseFromServer = reader.ReadToEnd();
    // Clean up the streams.
    reader.Close();
    dataStream.Close();
    response.Close();

    return responseFromServer;
}

这些是请求返回的标头:

Connection: keep-alive
Vary: Accept-Encoding
Content-Length: 7628
Cache-Control: private
Content-Type: text/html
Date: Tue, 06 Dec 2011 20:58:21 GMT
Set-Cookie: plaza%5Fmasteraccount=; expires=Tue, 06-Dec-2011 23:00:00 GMT; domain=; path=/,plaza%5Fvacmode=R; expires=Tue, 06-Dec-2011 23:00:00 GMT; domain=; pa
th=/,plaza%5Fname=%16%05%0C%0E%15%09%18%21QRQ; expires=Tue, 06-Dec-2011 23:00:00 GMT; domain=; path=/,plaza%5Flocked=R; expires=Tue, 06-Dec-2011 23:00:00 GMT; d
omain=; path=/,plaza%5Flogin=%16%05%0C%0E%15%09%18%21QRQ; expires=Tue, 06-Dec-2011 23:00:00 GMT; domain=; path=/,plaza%5Fid=S%5ENWNSQPP%40%15%08%0C%0E%15%09%18%
21QRQ%15%08%0C%0E%15%09%18%21QRQRQQ; expires=Tue, 06-Dec-2011 23:00:00 GMT; domain=; path=/,plaza%5Fmid=1323205117; expires=Sun, 25-Nov-2012 23:00:00 GMT; path=
/,plaza%5Fstatus=Q; expires=Tue, 06-Dec-2011 23:00:00 GMT; domain=; path=/,ASPSESSIONIDSQCRSDDR=NKHJIBADOGALNGKDBALDJBIA; path=/
Server: nginx
X-Powered-By: ASP.NET

1 个答案:

答案 0 :(得分:3)

您需要添加一个cookie容器。

CookieContainer cookieContainer = new CookieContainer();
// Create a request using a URL that can receive a post. 
HttpWebRequest request = (HttpWebRequest)WebRequest.Create(this.url);
request.CookieContainer = cookieContainer;

//DO your request that sets cookies from the server.
.........

//Place another request with the cookies
HttpWebRequest request = (HttpWebRequest)WebRequest.Create(someNewUrl);
request.CookieContainer = cookieContainer;
//this should have cookies from the previous request, which should keep you logged in.