c# webApi返回Excel数据流 || 使用Excel数据流的方式下载Excel
背景:
在前端无法生成特殊的excel表格,或操作复杂的时候会通过后台进行生成excel。但是服务器的资源也非常宝贵,所以通过数据流的方式就可以实现:不在服务器存储的情况下,使前端成功下载excel文件;
效果如下:

代码如下:
1,封装的方法:
/// <summary>
/// 导出excel模板
/// </summary>
/// <returns></returns>
public static byte[] OutputExcel()
{
try
{
NPOI.SS.UserModel.IWorkbook workbook = new NPOI.XSSF.UserModel.XSSFWorkbook();
NPOI.SS.UserModel.ISheet sheet = workbook.CreateSheet("sheet");
IRow Title = sheet.CreateRow(0);
for (int i = 0; i < 51; i++)
{
Title.CreateCell(i).SetCellValue("title" + i);
}
byte[] buffer = new byte[1024 * 5];
using (MemoryStream ms = new MemoryStream())
{
workbook.Write(ms, false);
//ms.Flush();
//ms.Position=0;
buffer = ms.ToArray();
ms.Close();
}
return buffer;
}
catch (Exception ex)
{
return null;
}
}
2,控制器方法:
[HttpGet(Name = "Test")]
public FileResult Test()
{
var result = ExcelHelper.OutputExcel();
return File(result, "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet", "UploadTemplate.xlsx");
}
c# webApi返回Excel数据流 || 使用Excel数据流的方式下载Excel的更多相关文章
- 使用ajax的post方式下载excel
		项目需求,前端发起ajax请求,后端生成excel并下载,同时需要在header头中,带上token验证信息,参考了很多文章,最终实现如下: PHP后端使用base64: $filename = 'd ... 
- asp.net 下载Excel (数据流,不保存)--客户端
		效果图: 前端页面 <html> <head> <title>Test For Excel</title> <script src="j ... 
- Angularjs 通过WebApi 下载excel
		如果想知道 AngularJs 通过WebAPI 下载Excel.请看下文,这里仅提供了一种方案. 服务器端代码如下: protected HttpResponseMessage GenereateE ... 
- 前端axios下载excel,并解决axios返回header无法获取所有数据的问题
		需求:通过后端接口下载excel文件,后端没有文件地址,返回二进制流文件 实现:axios(ajax类似) 主要代码: axios:设置返回数据格式为blob或者arraybuffer 如: var ... 
- 前端调用后端接口下载excel文件的几种方式
		今天有一个导出相应数据为excel表的需求.后端的接口返回一个数据流,一开始我用axios(ajax类库)调用接口,返回成功状态200,但是!但是浏览器没有自动下载excel表,当时觉得可能是ajax ... 
- C# Excel导入、导出【源码下载】
		本篇主要介绍C#的Excel导入.导出. 目录 1. 介绍:描述第三方类库NPOI以及Excel结构 2. Excel导入:介绍C#如何调用NPOI进行Excel导入,包含:流程图.NOPI以及C#代 ... 
- IE8下导入EXCEL数据传到客户端以附件下载
		IE8下导入EXCEL数据传到客户端以附件下载方式出现,而不显示数据,解决方法:以text/html格式返回. HttpResponseMessage message = new HttpRespon ... 
- java的poi技术下载Excel模板上传Excel读取Excel中内容(SSM框架)
		使用到的jar包 JSP: client.jsp <%@ page language="java" contentType="text/html; charset= ... 
- 在线读取Mongodb数据库下载EXCEL文件
		版本:Mongodb2.4.8 通过页面下载Excel文件 jsp <%@ page language="java" contentType="text/html; ... 
- C# 读取 Excel 最全最稳定的方式
		采用 NPOI 和 Epplus 方式读取Excel,因为之前测试NPOI的时候发现对于 .xlsx 格式的文件读取不是很友好,所以才结合了两个. 废话少说,直接上代码: public static ... 
随机推荐
- 【cef编译包】下载地址
			http://opensource.spotify.com/cefbuilds/index.html 
- springboot+thymeleaf+mybatis实现甘特图(代码非常详细)
			首先我们要明白:这个甘特图需要哪些动态数据. (1)需要:ID,tName,number,计划开始时间,开始时间,计划结束时间,结束时间,项目负责人,参与人,知情人ID,计划时长(可以计算得出的,不必 ... 
- 深度解读《深度探索C++对象模型》之数据成员的存取效率分析(一)
			接下来我将持续更新"深度解读<深度探索C++对象模型>"系列,敬请期待,欢迎关注!也可以关注公众号:iShare爱分享,自动获得推文和全部的文章列表. 在<深度解 ... 
- 力扣1(java&python)-两数之和(简单)
			题目: 给定一个整数数组 nums 和一个整数目标值 target,请你在该数组中找出 和为目标值 target 的那 两个 整数,并返回它们的数组下标. 你可以假设每种输入只会对应一个答案.但是, ... 
- 牛客网-SQL专项训练10
			①SQL语句中与Having子句同时使用的语句是:group by 解析: SQL语法中,having需要与group by联用,起到过滤group by后数据的作用. ②下列说法错误的是?C 解析: ... 
- Delta Lake基础介绍(商业版)
			简介:介绍 Lakehouse 搜索引擎的设计思想,探讨其如何使用缓存,辅助数据结构,存储格式,动态文件剪枝,以及 vectorized execution 达到优越的处理性能. 作者:李洁杏,Da ... 
- 淘宝推荐、视频搜索背后的检索技术竟是它!深度揭秘达摩院向量检索引擎Proxima
			简介: 淘宝搜索推荐.视频搜索的背后使用了什么样的检索技术?非结构化数据检索,向量检索,以及多模态检索,它们到底解决了什么问题?今天由阿里巴巴达摩院的科学家从业务问题出发,抽丝剥茧,深度揭秘达摩院内部 ... 
- KubeVela v1.2 发布:你要的图形化操作控制台 VelaUX 终于来了!
			简介:时间来到 2022 年,KubeVela 也正式进入了第四个阶段,在原先核心控制器 API 基本稳定的基础上,我们以插件的形式增加了一系列开箱即用的功能.让开发者可以通过 UI 控制台的方式, ... 
- Quick BI:降低使用门槛,大东鞋业8000家门店的数据导航
			简介: 通过引入MaxCompute和Quick BI,大东解决了以往数据查询即刻导致数据库闪崩的状况,还搭建起完善的报表体系,稳定应对高频.高并发的数据分析. 大东鞋业一季大约有500款的新品.大区 ... 
- 如何高效学习 Kubernetes 知识图谱?
			简介: Kubernetes 知识图谱遵循云原生人才学习路径搭建课程体系框架,及人才发展路线设置不同阶段,由浅入深,帮助云原生人才学习容器基础.Kuternetes 网络.存储.资源对象.服务发现. ... 
