2011-10-27 36 views
3

在下载使用HttpWebResponse文件由服务器发送的内容长度是错误的,导致HttpWebResponse停止通过下载该文件中途。 IE浏览器似乎没有这个问题。关于如何让HttpWebResponse忽略服务器发送的内容长度或者甚至是有意义的任何想法。 任何可以给予的帮助将不胜感激。HttpWebRequest的内容长度错误

--Example

class Program 
{ 
    static void Main(string[] args) 
    { 
     HttpWebRequest request = (HttpWebRequest)WebRequest.Create("http://localhost:59771/Default.aspx"); 
     HttpWebResponse response = (HttpWebResponse)request.GetResponse(); 

     Console.WriteLine("Content length: " + response.ContentLength); 

     int bytesRead = 0; 
     long totalBytesRead = 0; 

     byte[] data = new byte[1024 * 64]; 
     StringBuilder output = new StringBuilder(); 

     Stream responseStream = response.GetResponseStream(); 

     do 
     { 
      bytesRead = responseStream.Read(data, 0, 1024 * 64); 
      totalBytesRead += bytesRead; 

      output.Append(Encoding.ASCII.GetString(data, 0, bytesRead)); 
     } 
     while (bytesRead > 0); 

     Console.WriteLine("total read: " + totalBytesRead); 
     Console.WriteLine("last content read: " + output.ToString()); 
    } 

    protected void Page_Load(object sender, EventArgs e) 
    { 
     Response.Clear(); 
     Response.ClearHeaders(); 
     Response.AddHeader("Content-Length", "13"); 
     Response.Write("ABCDEFGHIJKLMNOPQRSTUVWXYZ"); 
    } 
} 

问题解决了!

我们从下拉数据的服务器是一个Cognos服务器,它正在计算内容长度,就好像要压缩字符串一样,但我们没有发送代码来表明我们可以接受压缩,所以它会发回未压缩的数据,但仅限于压缩的长度。 IE没有这个问题,因为它表示可以接受压缩。 代码来纠正问题:

request2.Headers.Add("Accept-Encoding", "gzip,deflate"); 
+0

您是否有我们可以访问的网址以查看我们自己的网址?谨慎与我们分享代码? –

回答

3

问题解决了!

我们从下拉数据的服务器是一个Cognos服务器,它正在计算内容长度,就好像要压缩字符串一样,但我们没有发送代码来表明我们可以接受压缩,所以它会发回未压缩的数据,但仅限于压缩的长度。 IE没有这个问题,因为它表示可以接受压缩。代码纠正问题:

request2.Headers.Add("Accept-Encoding", "gzip,deflate"); 
0

的HttpWebRequest无关与从服务器发送,只与你发送的数据的数据,所以我会假设你的意思HttpWebResponse。

HttpWebResponse完全不关心服务器发送的内容长度,它仅提供它的标题属性给客户作参考之用。

从响应流中读取时,你不应该依赖于服务器的内容长度,只是不停地读书,直到Stream.Read方法返回0

+1

我不认为'Stream.Read'将返回0,直到服务器超时,当'Connection:Keep-Alive'时。 –