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中没有任何内容(尽管我对此并不乐观).我知道这可能是一个很长的镜头,但有什么明显的我在这里缺少或我可以做些什么来更好地调试这个?
您需要添加以下内容:
model.File.InputStream.CopyTo(memoryStream);
memoryStream.Position = 0;
...
Product product = csvParser.Parse(memoryStream);
Run Code Online (Sandbox Code Playgroud)
将文件复制到MemoryStream时,指针将移动到流的末尾,因此当您尝试读取它时,您将获得一个空字节而不是流数据.您只需要将位置重置为开头,即0.
| 归档时间: |
|
| 查看次数: |
3787 次 |
| 最近记录: |