来自HTTPPostedFileBase的MVC / WebApi流

时间:2016-08-29 18:48:41

标签: c# asp.net-mvc gembox-spreadsheet asp.net-boilerplate

我正在尝试将来自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'的错误引发了以下异常:'此流不支持超时。'”当流是传递给方法。这是否有惯用的方法?

1 个答案:

答案 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);
}

我希望这会有所帮助。