我正在处理批量下载程序,但有些URL没有正确发送数据.
例如,此页面:http://i.imgbox.com/absMQK6A.png
在任何互联网浏览器中,此页面显示图像,但在我的程序中,下载奇怪的数据.
我认为这个URL是假的或受保护的(我不太了解HTML.)
顺便说一句,在IE中,我可以通过右键单击正常下载该图像并保存为图像.
所以我想在我的程序中模仿这种行为.
我怎样才能做到这一点?
以下是我的程序代码的一部分.
HttpWebRequest request = (HttpWebRequest)HttpWebRequest.Create(DownloadAddress);
if (Proxy != null)
{
request.Proxy = Proxy;
}
if (!string.IsNullOrWhiteSpace(UserAgent))
{
request.UserAgent = UserAgent;
}
HttpWebResponse response = (HttpWebResponse)request.GetResponse();
Stream downloadHttpStream = response.GetResponseStream();
int read = downloadHttpStream.Read(buffer,buffer.Length);
// output codes
UserAgent是具有浏览器信息的字符串.
如IE,Firefox等
谢谢.
最佳答案
如果您查看使用代码返回的数据的前几个字节,您可以看到它从1F 8B 08. This indicates开始,数据是gzip数据(gzip编码在Web上很常见).您可以包含
原文链接:https://www.f2er.com/html/426055.htmlAutomaticDecompression
属性以使.Net代码自动解压缩此数据并获得有效的PNG(字节以89 50 4E 47开头):
var request = (HttpWebRequest)HttpWebRequest.Create(DownloadAddress);
request.AutomaticDecompression = DecompressionMethods.GZip | DecompressionMethods.Deflate;