上传文件:MemoryStream与文件系统

Jas*_*Cav 4 asp.net-mvc file-upload

在我正在创建的业务应用程序中,我们允许管理员上传包含某些数据的CSV文件,这些数据会被解析并输入到我们的数据库中(正在进行所有适当的错误处理等).

作为升级到.NET 4.5的一部分,我不得不更新此代码的一些方面,并且,当我这样做时,我遇到了一个使用MemoryStream来处理上传文件的人的答案,而不是暂时保存到文件系统.我没有真正的理由要改变(也许它甚至可能不好),但我想尝试一下学习.所以,我快速换掉了这段代码(由于上传其他元数据,从强类型模型中):

HttpPostedFileBase file = model.File;
var fileName = Path.GetFileName(file.FileName);
var path = Path.Combine(Server.MapPath("~/App_Data/Uploads"), fileName);
file.SaveAs(path);

CsvParser csvParser = new CsvParser();
Product product = csvParser.Parse(path);

this.repository.Insert(product);
this.repository.Save();

return View("Details", product);
Run Code Online (Sandbox Code Playgroud)

对此:

using (MemoryStream memoryStream = new MemoryStream())
{
    model.File.InputStream.CopyTo(memoryStream);

    CsvParser csvParser = new CsvParser();
    Product product = csvParser.Parse(memoryStream);

    this.repository.Insert(product);
    this.repository.Save();

    return View("Details", product);
}
Run Code Online (Sandbox Code Playgroud)

不幸的是,当我这样做时,事情就会中断 - 我的所有数据都是以空值出现的,而且看起来好像MemoryStream中没有任何内容(尽管我对此并不乐观).我知道这可能是一个很长的镜头,但有什么明显的我在这里缺少或我可以做些什么来更好地调试这个?

Chr*_*att 6

您需要添加以下内容:

model.File.InputStream.CopyTo(memoryStream);
memoryStream.Position = 0;

...

Product product = csvParser.Parse(memoryStream);
Run Code Online (Sandbox Code Playgroud)

将文件复制到MemoryStream时,指针将移动到流的末尾,因此当您尝试读取它时,您将获得一个空字节而不是流数据.您只需要将位置重置为开头,即0.