- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我使用 Exceljs npm 模块在后端 (Express JS) 创建了一个 Excel 文件。我把它存储在临时目录中。现在我想将文件从后端发送到前端,并在用户单击按钮时将其下载到那里。我对两件事感到震惊 1.如何通过HTTP POST请求将文件从后端发送到前端 2.然后如何在前端下载文件
编辑内容:
我需要前端是一个按钮,将文件附加到它,然后下载它。这是我的代码的样子,我没有从后端到前端正确获取文件
前端文件:
function(parm1,parm2,parm3){
let url =${path}?parmA=${parm1}&parmB=${parm2}&parmC=${parm3};
let serviceDetails = {};
serviceDetails["method"] = "GET";
serviceDetails["mode"] = "cors";
serviceDetails["headers"] = {
"Content-Type": "application/json"
};
fetch(url, serviceDetails)
.then(res => {
if (res.status != 200) {
return false;
}
var file = new Blob([res], { type : 'application/octet-stream' });
a = document.createElement('a'), file;
a.href = window.URL.createObjectURL(file);
a.target = "_blank";
a.download = "excel.xlsx";
document.body.appendChild(a);
a.click();
document.body.removeChild(a);
}).catch(error => {
return false;
});
}`
router.js
var abc = ... // this is a object for the controller.js file
router.get('/path', function(req, res) {
abc.exportintoExcel(req, res);
});
controller.js
let xyz = ... //this is a object for the service.js file
exports.exportintoExcel = function(req, res) {
xyz.exportintoExcel(reqParam,res);
}
service.js
exportintoExcel(req,response){
//I have a excel file in my server root directory
const filepath = path.join(__dirname,'../../nav.txt');
response.sendFile(filepath);
})
}
最佳答案
这是对早期答案的完全重写,如果有人需要那个答案,我们深表歉意,但这个版本更胜一筹。我正在使用一个用 express-generator 创建的项目并在三个文件中工作:
index.ejs
从一个具有 download
属性的 anchor 标记开始,使用您想要的任何文件名和一个空的 href
属性。我们稍后将在 main.js 文件中的 href
中填充一个代表 Excel 文件的 ObjectURL:
<body>
<a id="downloadExcelLink" download="excelFile.xlsx" href="#">Download Excel File</a>
<script type="text/javascript" src="/javascripts/main.js"></script>
</body>
public/javascripts/main.js
选择 anchor 元素,然后向路径/downloadExcel
发出fetch()
请求。将响应转换为 Blob
,然后从该 Blob
创建一个 ObjectURL
。然后,您可以将 anchor 标记的 href
属性设置为此 ObjectURL
:
const downloadExcelLink = document.getElementById('downloadExcelLink');
(async () => {
const downloadExcelResponse = await fetch('/downloadExcel');
const downloadExcelBlob = await downloadExcelResponse.blob();
const downloadExcelObjectURL = URL.createObjectURL(downloadExcelBlob);
downloadExcelLink.href = downloadExcelObjectURL;
})();
routes/index.js
在索引路由器中,您只需调用res.sendFile()
函数并将其传递到您服务器上的Excel 文件的路径。
router.get('/downloadExcel', (req, res, next) => {
const excelFilePath = path.join(__dirname, '../tmp/excel.xlsx');
res.sendFile(excelFilePath, (err) => {
if (err) console.log(err);
});
});
就是这样!你可以找到一个 git repo here的项目。如果您无法让此代码按原样在您的项目中工作,请克隆它并亲自尝试。
工作原理
当页面加载时,4 个请求被发送到我们的服务器,正如我们在控制台输出中看到的那样:
GET / 200 2.293 ms - 302
GET /stylesheets/style.css 200 1.123 ms - 111
GET /javascripts/main.js 200 1.024 ms - 345
GET /downloadExcel 200 2.395 ms - 4679
前三个请求是针对 index.ejs (/)、CSS 样式表和我们的 main.js 文件的。第四个请求是通过调用 main.js 文件中的 fetch('/downloadExcel')
发送的:
const downloadExcelResponse = await fetch('/downloadExcel');
我在这条路线的 routes/index.js 中设置了路线处理程序,它使用 res.sendFile()
从我们的文件系统发送文件作为响应:
router.get('/downloadExcel', (req, res, next) => {
const excelFilePath = path.join(__dirname, '../tmp/excel.xlsx');
res.sendFile(excelFilePath, (err) => {
if (err) console.log(err);
});
});
excelFilePath
需要是您系统上文件的路径。在我的系统上,这是路由器文件和 Excel 文件的布局:
/
/routes/index.js
/tmp/excel.xlsx
从我们的 Express 服务器发送的响应存储在 downloadExcelResponse
中,作为调用 main.js 文件中的 fetch()
的返回值:
const downloadExcelResponse = await fetch('/downloadExcel');
downloadExcelResponse
是一个 Response
对象,出于我们的目的,我们希望使用 Response 将它变成一个
方法:Blob
对象。 blob()
const downloadExcelBlob = await downloadExcelResponse.blob();
现在我们有了 Blob
,我们可以调用 URL.convertObjectURL()
将这个 Blob
变成我们可以用作href
下载链接:
const downloadExcelObjectURL = URL.createObjectURL(downloadExcelBlob);
此时,我们在浏览器中有一个表示我们的 Excel 文件的 URL,我们可以通过将 href
添加到我们之前选择的 href 的 DOM 元素来将其指向该 URL
属性:
当页面加载时,我们用这一行选择 anchor 元素:
<a id="downloadExcelLink" download="excelFile.xlsx" href="#">Download Excel File</a>
因此我们将 URL 添加到 href
中,在发出 fetch
请求的函数中:
downloadExcelLink.href = downloadExcelObjectURL;
您可以在浏览器中检查该元素,并看到 href
属性在页面加载时已更改:
注意,在我的电脑上, anchor 标签现在是:
<a id="downloadExcelLink" download="excelFile.xlsx" href="blob:http://localhost:3000/aa48374e-ebef-461a-96f5-d94dd6d2c383">Download Excel File</a>
由于 download
属性出现在链接上,单击链接时,浏览器将下载 href
指向的任何内容,在我们的例子中是 URL到表示 Excel 文档的 Blob
。
我从这些来源提取了我的信息:
这是下载过程在我的机器上的样子的 gif:
关于node.js - 从后端发送一个Excel文件到前端,并在前端下载,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58923772/
我正在使用 voip 推送通知制作 ios 应用程序。 我想从 Node js 发送 voip 推送通知,但不是很好。 我阅读了本教程 CallKit iOS Swift Tutorial for V
我编写了一个服务器,当浏览器尝试连接到某些站点时,它会检查黑名单并发回 404,但是当我调用 send() 时没有错误,但消息不会出现在网络上浏览器,除非我关闭连接? 有什么建议吗? 接受来自浏览器的
#include int main() { char c = getchar(); //EOF (ctrl + d ) while( ( c = getchar() ) != '?'
我正在尝试使用MailMessage对象通过PowerShell发送电子邮件。该脚本使用Import-CSV来使用文件,然后在电子邮件正文中使用ConvertTo-HTML。由于我要发送的电子邮件客户
我需要创建一个脚本,每 30 秒对网络流量进行一次采样并存储发送/接收的字节。该数据随后用于绘制图形。我编写了一个在 Windows 2012 上完美运行的程序,但我意识到某些 cmdlet 在以前的
我正在运行“autoit3.chm”文件。当它运行时,我想发送一个向下键箭头,但它不起作用: $file = FileGetShortName("C:\Users\PHSD100-SIC\Deskto
当我使用网络浏览器测试我的程序时,我可以很好地写入套接字/FD,所以我决定循环它并在连接中途切断连接,我发现了一个问题。 send() 能够在套接字不可用时关闭整个程序。我认为问题在于该程序陷入了第
我正在运行“autoit3.chm”文件。当它运行时,我想发送一个向下键箭头,但它不起作用: $file = FileGetShortName("C:\Users\PHSD100-SIC\Deskto
所以我试图向自己发送数据并接收数据然后打印它,现在我已经测试了一段时间,我注意到它没有发送任何东西,事实上,也许它是,但我没有正确接收它,我需要这方面的帮助。 这就是我用来发送数据的
问题:开发人员创建自己的序列化格式有多常见?具体来说,我使用 java 本质上将对象作为一个巨大的字符串发送,并用标记来分隔变量。 我的逻辑:我选择这个是因为它几乎消除了语言依赖性(忽略java的修改
我必须在 Linux 上编写一个应用程序,该应用程序需要与具有自定义以太网类型的设备进行通信。甚至在如何编写这样的应用程序中也有很多解决方案。一个缺点是需要 root 访问权限(AFAIK)。之后释放
我有一个包含三个单选按钮选项的表单。我需要将表单数据提交到另一个文件,但由于某种原因,发送的数据包含所选单选按钮的值“on”,而不是 value 属性的值。 我尝试通过 post() 函数手动操作和发
基本上我想实现这样的目标: Process 1 Thread 1 Receive X from process 2 Thread 2 Receive Y from proces
我目前正在 Google App Engine 上开发一个系统,对它还很陌生,我正在使用 Java 平台进行开发。我在 servlet 之间发送 session 对象时遇到问题。我已经在 appeng
当我尝试将“this”(触发的元素)作为参数发送给函数时,函数收到“Object[Document build.php]”作为参数,而不是触发的元素。请让我知道我的错误: function set(a
我正在寻找让我的应用响应联系人 > 发送的魔法咒语。我希望能够接收联系人的 URI 以便检索联系人。谁有 list 过滤器/代码 fragment 吗? 最佳答案 我没有睾丸,但您可以尝试基于 ACT
关于我心爱的套接字的另一个问题。我先解释一下我的情况。之后我会告诉你是什么困扰着我。 我有一个客户端和一个服务器。这两个应用程序都是用 C++ 编写的,实现了 winsock2。连接通过 TCP 和
我看到了这篇文章 http://www.eskimo.com/~scs/cclass/int/sx5.html 但这部分让我感到困惑:如果我们已经使用 send_array 或 send_array_
我对这行代码有疑问。我必须将一个数据包带到一个端口并重新发送到接口(interface)(例如:eth0)。我的程序成功地从端口获取数据包,但是当我重新发送(使用 send())到接口(interfa
我正在尝试编写一个 X11 输入驱动程序,它可以使用我的 Android 手机上的触摸屏来移动和单击鼠标。我可以正常移动鼠标,但我无法让应用程序正确识别点击。我当前的代码位于 https://gist
我是一名优秀的程序员,十分优秀!