HttpWebResponseを使用してファイルをダウンロードすると、サーバーによって送信されたコンテンツの長さが間違っているため、HttpWebResponseは途中でファイルのダウンロードを停止します。あなたがブラウズするとき、IEはこの問題を抱えていないようです。 HttpWebResponseにコンテンツの長さを無視させる方法についてのアイデア。
何か助けてもらえれば幸いです。
- 例
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");