【问题标题】:Remember authentication with web request记住使用 Web 请求进行身份验证
【发布时间】:2011-12-06 20:51:25
【问题描述】:

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

我能够将用户数据发送到登录表单并获取欢迎屏幕的信息。但是当我发送另一个请求时,网站忘记了我曾经登录过。 我读到我必须以某种方式启用 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

【问题讨论】:

  • 你需要读取响应头中的cookies...保存它们并与后续请求一起发送。
  • 真的不足以继续提供完整的答案。您真正需要做的是在后续请求的响应中包含返回的 cookie 集合。但是,根据这段代码,我不知道该 cookie 的格式或内容应该是什么。
  • 我已将 http 标头添加到我的问题中。

标签: c# authentication httpwebrequest


【解决方案1】:

您需要添加一个 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.

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2014-10-02
    • 1970-01-01
    • 1970-01-01
    • 2018-06-06
    • 1970-01-01
    • 2013-05-30
    相关资源
    最近更新 更多