作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我想通过 NodeJS 将文件上传到我的 Azure Blob 存储。到目前为止,我通过 express-fileupload
将文件上传到我的服务器,它们存储在其磁盘上,然后上传到 Azure blob 存储。现在我想在上传文件的同时将它们上传到Azure,即在将它们上传到Azure之前不要将它们保存在服务器磁盘上。这是我到目前为止使用的方法:
router.post('/upload', function(req, res) {
"use strict"
if (!req.files)
return res.status(400).send('No files were uploaded.');
// The name of the input field (i.e. "sampleFile") is used to retrieve the uploaded file
let context = req.files.context;
let filenameContext = req.files.context.name;
context.mv('../'+filenameContext, function(err) {
if (err)
return res.status(500).send(err);
else {
blobSvc.createBlockBlobFromStream(containerName, filenameContext, context, function(error, result, response){
if(!error){
console.log(filenameContext+" stored in blob");
fs.unlink('../'+filenameContext, function() {
if (err) throw err;
});
} else {
console.error(filenameContext+" storing in blob failed");
}
});
}
});
有什么方法可以将上传的文件直接转换为流以使用createBlockBlobFromStream
方法而不先将文件存储在服务器磁盘上?
最佳答案
我建议使用 createBlockBlobFromText
相反:
app.post('/upload', function(req, res) {
if (!req.files)
return res.status(400).send('No files were uploaded.');
let data = req.files.context.data;
let filename = req.files.context.name;
blobSvc.createBlockBlobFromText(containerName, filename, data, function(err) {
if (err)
return res.status(500).send(err);
res.send('File uploaded!');
})
})
关于node.js - 使用 NodeJS 和 express-fileupload 将文件上传到服务器,并将其直接流式传输到 Azure 云,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47497538/
我是一名优秀的程序员,十分优秀!