关于MVC控制器导出Excel时MemoryStream流已关闭的问题

简介:      在MVC控制器导出Excel时遇到一个问题,当我关闭流时,无法导出Excel文件代码: MemoryStream ms = bll.
     在MVC控制器导出Excel时遇到一个问题,当我关闭流时,无法导出Excel文件
代码: MemoryStream ms = bll.GetOrdersExcel(info, ul, filePath,tempPath);
  try
            {
                {
                    if (ms == null)
                    {
                        return Content("导出Excel异常,请联系客服", "text/html");
                    }
                    else
                    {
                        flag = true;
                        ms.Seek(0, SeekOrigin.Begin);
                        return File(ms , "application/ms-excel", fileName);
                    }
                }
            }
            catch (Exception ex)
            {
                LogWrite.Logger("FileExportExcel:" + ex.Message.ToString(), LogEnum.Error);
                return Content("导出Excel异常,请联系客服", "text/html");
            }
            finally
            {
                if (flag)
                {
                    System.IO.File.Delete(System.Web.HttpContext.Current.Server.MapPath(filePath));
                }
                ms.Dispose();
            }
这样写一直报错,因为return 的时候 ms流已经背dispose()了,所以会导致无法找到关闭的流的错误,
找了半天的办法,发现这个问题很简单,只要将ms 用中间量存下来即可,
   byte[] mst = ms.ToArray();//转为byte数组以便于关闭ms
然后将return File(ms , "application/ms-excel", fileName); 改为return File(mst , "application/ms-excel", fileName);就可以了


      如果大家有更好的办法欢迎留言,共同学习!
目录
相关文章
|
1月前
|
NoSQL 关系型数据库 MySQL
多人同时导出 Excel 干崩服务器?怎样实现一个简单排队导出功能!
业务诉求:考虑到数据库数据日渐增多,导出会有全量数据的导出,多人同时导出可以会对服务性能造成影响,导出涉及到mysql查询的io操作,还涉及文件输入、输出流的io操作,所以对服务器的性能会影响的比较大;结合以上原因,对导出操作进行排队; 刚开始拿到这个需求,第一时间想到就是需要维护一个FIFO先进先出的队列,给定队列一个固定size,在队列里面的人进行排队进行数据导出,导出完成后立马出队列,下一个排队的人进行操作;还考虑到异步,可能还需要建个文件导出表,主要记录文件的导出情况,文件的存放地址,用户根据文件列表情况下载导出文件。
多人同时导出 Excel 干崩服务器?怎样实现一个简单排队导出功能!
|
2月前
|
XML Java 数据格式
使用Freemarker模版导出xls文件使用excel打开提示文件损坏
使用Freemarker模版导出xls文件使用excel打开提示文件损坏
49 0
|
29天前
|
前端开发 Java Spring
ssm中spring mvc找不到控制器,报错404
ssm中spring mvc找不到控制器,报错404
14 0
|
29天前
mvc.net分页查询案例——控制器(HomeController.cs)
mvc.net分页查询案例——控制器(HomeController.cs)
8 0
|
1月前
|
设计模式 前端开发 数据处理
MVC架构中,控制器和模型之间是如何交互的
MVC架构中,控制器和模型之间是如何交互的
9 0
|
1月前
|
存储 设计模式 前端开发
请解释 Web 应用程序的 MVC(模型-视图-控制器)架构。
【2月更文挑战第26天】【2月更文挑战第89篇】请解释 Web 应用程序的 MVC(模型-视图-控制器)架构。
|
1月前
|
SQL Java easyexcel
【Java】百万数据excel导出功能如何实现
【Java】百万数据excel导出功能如何实现
116 0
|
2月前
|
Java
使用POI导出Excel
使用POI导出Excel
|
2月前
|
前端开发 Java Maven
springboot优雅的实现excel的导出(自适应列宽实现,中文也行),复制可用
springboot优雅的实现excel的导出(自适应列宽实现,中文也行),复制可用
56 0