Warning: file_get_contents(/data/phpspider/zhask/data//catemap/6/entity-framework/4.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
通过web api下载Excel文件。腐败_Excel_Entity Framework_Asp.net Web Api_Webclient Download - Fatal编程技术网

通过web api下载Excel文件。腐败

通过web api下载Excel文件。腐败,excel,entity-framework,asp.net-web-api,webclient-download,Excel,Entity Framework,Asp.net Web Api,Webclient Download,我正在尝试通过Web API(使用实体框架)下载excel文件。下载工作正常,但我在尝试打开文件时收到一些关于文件损坏的错误对话框 Web API代码如下所示: public HttpResponseMessage GetValue(int ID, string name) { MemoryStream stream; try { using (DataContext db = new DataContext()) { dyn

我正在尝试通过Web API(使用实体框架)下载excel文件。下载工作正常,但我在尝试打开文件时收到一些关于文件损坏的错误对话框

Web API代码如下所示:

  public HttpResponseMessage GetValue(int ID, string name)
    {

    MemoryStream stream;
    try {
        using (DataContext db = new DataContext()) {
            dynamic fileObj = (from c in db.FileList c.ID == IDc).ToList();
            stream = new MemoryStream(fileObj(0).File);
            HttpResponseMessage result = new HttpResponseMessage(HttpStatusCode.OK);
            result.Content = new StreamContent(stream);
            result.Content.Headers.ContentType = new MediaTypeHeaderValue(fileObj(0).FileContentType);
            result.Content.Headers.ContentDisposition = new ContentDispositionHeaderValue("attachment") { FileName = name };
            return result;
        }
    } catch (Exception ex) {
        return Request.CreateResponse(HttpStatusCode.InternalServerError);
    }
}
它打开文件时显示两个错误对话框和以下消息

Excel已完成文件级验证和修复。此工作簿的某些部分可能已被修复或丢弃


我也有同样的问题,问题不在web api代码中,而是在客户端代码中。对我来说,我使用的是jquery。下面的代码为我修复了它

我正在根据结果创建一个blob,这不是必需的,因为结果已经是一个blob

 window.URL.createObjectURL(result);
请注意,我是直接从结果创建对象的。下面是完整的Jquery代码


试图解决同样的问题。我比较了两个ePlus版本:4.5.3.3和5.2.1。后者包括一个用于在GetAsByteArray过程中关闭流的代码。所以,我刚刚在4.5.3.3版本中添加了这些行,它就像一个魅力。看起来该流最初包含一些垃圾位,在将文件数据泵入该流之前必须删除这些垃圾位。 使用NetCore 3.1 web应用程序进行测试。希望它能解决你的问题

if (save)
{
    Workbook.Save();
    _package.Close();

    /* start of added code */
    if (_stream is MemoryStream && _stream.Length > 0)
    {
        CloseStream();
    }
    /* end of added code */

    _package.Save(_stream);
}


上传后的文件代码。还有一个旁注:在不必要的情况下返回InternalServerError on exception,这是web api的默认行为。您解决过这个问题吗?是的。我确实解决了。将文件上载到SQL Server的代码中有错误。下载是正确的。所以修复了上传,一切正常。你有类似的问题吗?如果我能找到,我可以发布代码。我也有同样的问题。我正在使用EPPlus生成excel文件。如果我在控制台应用程序中生成它并将其保存在文件系统中,excel工作正常。如果我在web API中发送与HttpResponseMessage相同的流,我将收到相同的修复警报。单击“是”后,excel将正常打开。但我想删除那个警报。可能是上传错误!你能粘贴上传代码(web api)吗?我现在没有旧的代码,因为它是为一个客户端完成的
if (save)
{
    Workbook.Save();
    _package.Close();

    /* start of added code */
    if (_stream is MemoryStream && _stream.Length > 0)
    {
        CloseStream();
    }
    /* end of added code */

    _package.Save(_stream);
}