最近做个下载工具,请求json格式的数据都能请求下来,请求文件数据body体里面空,浏览器复制连接可以下载文件,最后在浏览器里面查看了下请求的报文,尝试把请求报文header拼接上,就能下载了,一下是代码
`这里写代码片
`public static void downfile(string filename, string filePath, string url, List<KeyValuePair<string, string>>paramArray)
{
try
{
System.IO.FileStream fs;
var client = new HttpClient();
url = url + "?" + BuildParam(paramArray);
client.DefaultRequestHeaders.Add("User-Agent", @"Mozilla/5.0 (compatible; Baiduspider/2.0; +http://www.baidu.com/search/spider.html)");//添加自主驱动 很重要,没细研究,确实添加上就能下载文件
client.DefaultRequestHeaders.Add("Accept", @"text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8");//添加数据格式
var bytes = client.GetByteArrayAsync(url).Result;
if (File.Exists(filePath + "//" + filename))
{
File.Delete(filePath + "//" + filename);
}
fs = new System.IO.FileStream(filePath + "//" + filename, System.IO.FileMode.CreateNew);
fs.Write(bytes, 0, bytes.Length);
fs.Close();
}
catch(Exception es)
{
MessageBox.Show(es.ToString());
}
}