C# WebClient下载文件已损坏

C# WebClient下载文件已损坏,c#,.net,webclient,downloadfile,C#,.net,Webclient,Downloadfile,我正在尝试使用C#WebClient下载一个文件 以下是网址: 如果我手动下载,一切看起来都正常。 但是,如果我使用WebClient下载文件,则内容已损坏。 我尝试过使用许多不同的编码方法。 下面是重现问题的最少代码 class Program { static void Main(string[] args) { WebClient client = new WebClient(); client.Proxy = new WebProxy("

我正在尝试使用C#WebClient下载一个文件

以下是网址:

如果我手动下载,一切看起来都正常。 但是,如果我使用WebClient下载文件,则内容已损坏。 我尝试过使用许多不同的编码方法。 下面是重现问题的最少代码

class Program
{
    static void Main(string[] args)
    {
        WebClient client = new WebClient();
        client.Proxy = new WebProxy("some company proxy");
        string url = "http://www.czce.com.cn/cn/DFSStaticFiles/Future/2018/20180821/FutureDataClearParams.txt";
        client.DownloadFile(url, @"D:\file.txt");
    }
}
问题现在解决了,谢谢大家的帮助(@Gauravsa,@John)。 该文件确实是gzip文件

解决办法是:

public class MyWebClient : WebClient
{
    protected override WebRequest GetWebRequest(Uri address)
    {
        HttpWebRequest request = base.GetWebRequest(address) as HttpWebRequest;
        request.AutomaticDecompression = DecompressionMethods.Deflate | DecompressionMethods.GZip;
        return request;
    }
}
我测试它并工作

例如,看看这个控制台应用程序。它将从URL下载您的文件,并将其保存到桌面上,格式为file.txt.:

class Program
{
    static void Main(string[] args)
    {
    WebClient client = new WebClient();
                string address = "http://www.czce.com.cn/cn/DFSStaticFiles/Future/2018/20180821/FutureDataClearParams.txt";
                // Save the file to desktop for debugging
                var desktop = Environment.GetFolderPath(Environment.SpecialFolder.Desktop);
                string fileName = desktop + "\\file.txt";
                client.DownloadFile(address, fileName);
    }
}
使用:

您可以执行其他文件I/O操作,如

if(!Directory.Exists("c:\\Users\\Jon\\Test\\")
    Directory.CreateDirectory("c:\\Users\\Jon\\Test\\");

您能解释一下它是如何损坏的吗?请发布一些代码,最好是a。您是如何确定文件的编码是UTF-8的?
WebClient。上传时使用编码,而不是下载时使用编码。在下载时,使用服务器设置的编码,因此这是一种误导。@Lasse和
DownloadFile
工作正常。我得到的文件与通过网络浏览器下载的文件完全相同(因此我对这个问题投了反对票)。这不应该作为评论发布吗?正如“好的,它对我来说很好。你能发布一个演示问题的帖子吗?”@John,我已经用一个最小的完整和可验证的示例更新了代码,除了代理部分,我还附加了损坏的结果,如果它有帮助的话。我已经尝试过了,如果你打开foo.txt,一切都已损坏。与手动下载的resultUse Fiddler进行比较,了解在HTTP级别发生的情况。您需要找出服务器需要什么作为输入,才能以正确的内容作出响应。@David您能否改进您的问题,以便人们能给您提供有用的答案
DownloadFile
对我来说效果很好,与通过Google Chrome下载的文件完全相同。@David:服务器可能会以GZip格式返回文件可能的解决方案:
using (WebClient client = new WebClient())
{
        client.DownloadFile("http://www.czce.com.cn/cn/DFSStaticFiles/Future/2018/20180821/FutureDataClearParams.txt", 
                            "c:\\Users\\Jon\\Test\\foo.txt");
}
if(!Directory.Exists("c:\\Users\\Jon\\Test\\")
    Directory.CreateDirectory("c:\\Users\\Jon\\Test\\");