2

我正在访问一个返回 pdf 文件作为响应的 httpwebrequest。我正在将该响应读入内存流,然后再转换为文件。问题是,正在创建数百个文件。不知道为什么,我尝试了很多方法,并且都做了同样的事情......这是第一个返回内存流的方法。

        MemoryStream memStream = new MemoryStream();
        byte[] buffer = new byte[2048];

        int bytesRead = 0;
        do
        {
            bytesRead = _ResponseStream.Read(buffer, 0, buffer.Length);
            memStream.Write(buffer, 0, bytesRead);
        } while (bytesRead != 0);

其次要转换为 FileStream ...

            byte[] data = stream.ToArray();

            FileStream fs = new FileStream(newFile, FileMode.CreateNew);
            fs.Write(data, 0, data.Length);

有任何想法吗?

编辑以添加更多代码...

    public MemoryStream GetToStream()
    {
        if (_Req == null)
            throw new Exception("HttpWebRequest is not initialised");

        GetResult(_Req);

        MemoryStream memStream = new MemoryStream();
        byte[] buffer = new byte[2048];

        int bytesRead = 0;
        do
        {
            bytesRead = _ResponseStream.Read(buffer, 0, buffer.Length);
            memStream.Write(buffer, 0, bytesRead);
        } while (bytesRead != 0);

        _ResponseStream.Close();

        if (memStream.Length > 0)
            return memStream;
        else return null;
    }

newFile 是要创建的文件的服务器的映射路径。

            byte[] data = stream.ToArray();

            FileStream fs = new FileStream(newFile, FileMode.Create);
            fs.Write(data, 0, data.Length);
            fs.Close();

我试过stream.WriteTo(fs),同样的事情发生了。相当离奇。

4

2 回答 2

13

完全不清楚为什么你会得到多个文件,但你应该能够根据文件名获得一些信息——每个文件都对应一个newFile.

顺便说一句,我注意到您没有关闭文件流。使用File.WriteAllBytes是实现目标的一种更简单的方法,并且不需要您关闭任何东西:

byte[] data = stream.ToArray();
File.WriteAllBytes(newFile, data);

另一种方法是仍然使用 a FileStream(with a usingstatement),但使用它MemoryStream.WriteTo来避免ToArray必须复制所有数据的调用:

using (FileStream fs = File.Create(newFile))
{
    stream.WriteTo(fs);
}
于 2009-02-17T07:39:17.730 回答
0

我建议您从客户那里收到的请求比您想象的要多。检查您的网络服务器访问日志文件。您显示的代码片段看起来很合理,但并没有真正显示足够的代码来解释问题 - 您没有显示代码的正确部分。无论如何,检查访问日志或使用某种跟踪。

于 2009-02-17T07:36:16.490 回答