我正在尝试将来自HttpPostedFileBase的流传递给服务方法而不保存到磁盘。
//Controller Action
[HttpPost]
public void Import()
{
if (Request.Files.Count == 0)
return new HttpStatusCodeResult(404);
var file = Request.Files[0];
_departmentAppService.Import(file.InputStream);
}
//Service Method
public string Import(Stream stream)
{
var excelFile = ExcelFile.Load(stream, LoadOptions.CsvDefault);
var worksheet = excelFile.Worksheets[0];
var jsonString = worksheet.ToJsonString();
return jsonString;
}
对象'System.Web.HttpInputStream'上的“属性访问者'ReadTimeout'的错误引发了以下异常:'此流不支持超时。'”当流是传递给方法。这是否有惯用的方法?
答案 0 :(得分:0)
我无法重现此问题,因此我无法检查您获得的堆栈跟踪,但是我认为您已经超时,因为您正在处理大型CSV文件,在这种情况下我会尝试增加& #39; executionTimeout'在web.config中。
您也可以尝试使用临时内存流来存储上传的文件,如下所示:
var file = Request.Files[0];
using (var tempStream = new MemoryStream())
{
file.InputStream.CopyTo(tempStream);
tempStream.Position = 0;
_departmentAppService.Import(tempStream);
}
我希望这会有所帮助。