- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
每当我上传图像时,req.files 都会返回未定义。这是我的代码:
var upload123 = multer({
dest: path.join(__dirname, 'public/upload/temp'),
});
app.post(upload123);
这是 HTML:
<form action="/images" method="POST" enctype="multipart/form-data">
<div class="panel-body form-horizontal">
<div class="form-group col-md-12">
<label for="file" class="col-md-2 control-label">Browse:</label>
<div class="col-md-10">
<input type="file" class="form-control" id="file" name="file">
</div>
</div>
这是我尝试访问 req.files 的 Controller :
create(req, res) {
const saveImage = function() {
const possible = 'abcdefghijklmnopqrstuvwxyz0123456789';
let imgUrl = '';
for(let i = 0; i < 6; i++) {
imgUrl += possible.charAt(Math.floor(Math.random() * possible.length));
}
Models.Image.find({ filename: imgUrl }, (err, images) => {
if (images.length > 0) saveImage();
else {
var tempPath = req.files.file.path,
ext = path.extname(req.files.file.name).toLowerCase(),
targetPath = path.resolve(`./public/upload/${ imgUrl }${ ext }`);
if (ext === '.png' || ext === '.jpg' || ext === '.jpeg' || ext === '.gif') {
fs.rename(tempPath, targetPath, (err) => {
if (err) throw err;
var newImg = new Models.Image({
title: req.body.title,
description: req.body.description,
filename: imgUrl + ext
});
newImg.save((err, image) => {
res.redirect(`/images/${image.uniqueId}`);
});
});
} else {
fs.unlink(tempPath, () => {
if (err) throw err;
res.json(500, {error: 'Only image files are allowed'});
})
}
}
});
}
saveImage();
}
我正在使用 Express 版本 4.16.3 和 Multer 1.3.0。我检查了文档,但无法弄清楚如何在 Multer 中简单地提供 dest
选项。请帮忙,我是 Nodejs 新手
最佳答案
这是正常工作的代码示例:
const multer = require('multer');
const storage = multer.memoryStorage();
const fileUpload = multer({storage});
app.use('/*', fileUpload.single('file'));
如果您在应用程序的开头有这个,并且您将 Controller 放在这个中间件之后,那么在 req.file
中您将拥有文件
最好的事情是它直接存储在内存中,而不是存储在某个文件中,因此您不必从文件系统加载它。 (这也更安全,特别是当您将应用程序部署到某些云服务和容器时,这使其不那么明显)
<小时/>如果您坚持使用“磁盘文件”解决方案,根据官方文档:https://www.npmjs.com/package/multer你应该这样使用它:
var upload123 = multer({
dest: path.join(__dirname, 'public/upload/temp'),
});
app.post('/endpoint/to/upload/photos', upload123.single('file'), controller.handleImage);
关于node.js - Express Multer req.files 未定义,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49732301/
我有这个用于上传文件的中间件。 @Injectable() export class FilesMiddleware implements NestMiddleware { private sto
我在使用 multer 和 multer-s3 npm 以及 node.js 和express 将图像上传到 S3 时遇到问题。 我已阅读 multer 和 multer-s3 的文档并按照教程进行操
任何人都知道为什么“重命名”函数(以及所有其他 multer 回调)不起作用? var express = require('express'); var multer = require('mul
我有这个nodejs应用程序。很简单。 var express = require('express'); var multer = require('multer'); var upload = m
routes.js module.exports=function(app, upload){ var postingsController=require('../controlle
我正在使用 FormData 上传文件并使用 Multer 在服务器端接收该文件。一切都按预期工作,除了因为我在前端使用 FileSystem API ( https://developer.mozi
我正在使用multer要将图像上传到快速服务器,默认情况下 multer 会创建自动生成/随机文件名(这通常很好),但在我的特殊情况下,我需要文件名与原始文件名相同,我尝试了以下方法: const u
我对 multer/node/express/mongoose/... 相当陌生,我目前正在尝试从具有相同名称的不同输入上传多个文件(我使用reactjs 生成输入)。 这是我的 React 前端:
我正在尝试使用 multer 将文件从客户端的 html 表单上传到服务器端,multer 模块在服务器端处理文件。 这里的事情是一切正常,因为我从服务器收到 200 ok 响应,但文件应该上传到我的
我在 Internet 上到处查看,但没有发现任何看起来像我的问题。我是 Node.JS 的新手,我想使用 Multer 上传两张不同的图片,但格式相同。这是我的表格: Add a prof
我这辈子都无法使 multer 的文件上传正常工作。我已经阅读了数十个教程,遵循了 YT 指南,并搜索了数十个 StackOverflow 问题,但无法通过 Postman 解决问题。 这是路由的页面
我想在单个 post 请求中保存一张图像,这将是用户对 MongoDB 的头像,以及一些用户的信息,使用来自 npm 的名为 multer 的包。不幸的是,只有我在控制台中看到的是错误:TypeErr
我正在使用 Multer 来管理图像上传,当在本地计算机上运行我的应用程序时,一切都运行良好。但现在我尝试部署到 Heroku,我在应用程序日志中收到此错误: Unhandled rejection
我在使用 Multer 保存多个图像时遇到问题 路线如下: router.post('/imagesSection', upload.array('up
我使用 multer . 问题 1 当我将以下代码段放入 app.js app.use(multer({ dest: './uploads' } ).single('file'
我有一个这样的对象数组: data: [ {"image": File, "certificate": File}, {"image": File, "certificate": Fi
我知道我可以通过 multer 通过存储对象更改文件名,如下所示: const storage = multer.diskStorage({ destination: (req, file,
我正在使用 Multer保存我通过表单上传的文件,但我不知道为什么我的代码将它保存为一个奇怪的名称并且没有扩展名,我刚刚使用了文档中的代码。 server.js: const multer = re
我正在尝试将图像(jpg/jpeg/png)从浏览器上传到 NodeJS。我已经阅读了几个教程和论坛上的许多帖子,但似乎很少有人遇到这个特定问题。 我已确保将提供给 multer 的名称 ( uplo
我创建了一个 node.js 服务器,并使用 multer 模块上传一些文件。 我的问题是:我该如何处理错误?就像客户端关闭直到上传完成?抱歉英语不好,我是意大利人。 这是我实际不起作用的代码: va
我是一名优秀的程序员,十分优秀!