C#:WebClientは、実際のリソースの代わりにHTMLページのソースコードをダウンロードします
-
26-10-2019 - |
質問
MSDNブログの1つからこのコードを採用し、WebClientを追加してリソースをダウンロードしました。
string formUrl = "My login url";
string formParams = string.Format("userName={0}&password={1}&x={2}&y={3}&login={4}", "user", "password","0","0","login");
string cookieHeader;
WebRequest req = WebRequest.Create(formUrl);
req.ContentType = "application/x-www-form-urlencoded";
req.Method = "POST";
byte[] bytes = Encoding.ASCII.GetBytes(formParams);
req.ContentLength = bytes.Length;
using (Stream os = req.GetRequestStream())
{
os.Write(bytes, 0, bytes.Length);
}
WebResponse resp = req.GetResponse();
cookieHeader = resp.Headers["Set-cookie"];
string pageSource;
string getUrl = "Resource url";
WebRequest getRequest = WebRequest.Create(getUrl);
getRequest.Headers.Add("Cookie", cookieHeader);
WebResponse getResponse = getRequest.GetResponse();
using (StreamReader sr = new StreamReader(getResponse.GetResponseStream()))
{
pageSource = sr.ReadToEnd();
System.Console.WriteLine(sr.ToString());
}
WebClient wc = new WebClient();
wc.Headers["Content-Type"] = "application/x-www-form-urlencoded";
wc.DownloadFile("Resource url","C:\\abc.tgz");
Console.Read();
しかし、ABC.TGZはそうあるべきではありません。それで、メモパッドを使用してそれを開いたとき、それが「私のログインURL」ページのソースファイルであることに気付きました。
エラーを確認するために使用できるWebClientのプロパティはありますか。つまり、ベースアドレスなどはありますか?
解決
物事をより簡単にしましょう、私たちは次のとおりです。
public class CookiesAwareWebClient : WebClient
{
public CookieContainer CookieContainer { get; private set; }
public CookiesAwareWebClient()
{
CookieContainer = new CookieContainer();
}
protected override WebRequest GetWebRequest(Uri address)
{
var request = base.GetWebRequest(address);
((HttpWebRequest)request).CookieContainer = CookieContainer;
return request;
}
}
class Program
{
static void Main()
{
using (var client = new CookiesAwareWebClient())
{
var values = new NameValueCollection
{
{ "userName", "user" },
{ "password", "password" },
{ "x", "0" }, // <- I doubt the server cares about the x position of where the user clicked on the image submit button :-)
{ "y", "0" }, // <- I doubt the server cares about the y position of where the user clicked on the image submit button :-)
{ "login", "login" },
};
// We authenticate first
client.UploadValues("http://example.com/login", values);
// Now we can download
client.DownloadFile("http://example.com/abc.tgz", @"c:\abc.tgz");
}
}
}
ちなみに、コードの問題は、保護されたリソースにアクセスすることになっている2番目の要求に最初の要求を送信したときに、サーバーが発行した認証Cookieを渡さないことです。あなたが合格するのは、いくつかのコンテンツタイプとクッキーなどがありません。 Cookieのようなサーバー:-)
所属していません StackOverflow