在通过multer,nodejs中上传文件时问题
我正在尝试通过Multer和nodejs向MongoDB添加Pictire。 创建了multer存储。 基于称为上传的multer的中间件插入到邮政请求中。 但是,当我执行帖子请求时, req.file不确定 。 这是什么原因?
路线:
const express = require('express');
const Menu = require("../models/menu");
const Image = require("../models/image");
const router = express.Router();
const multer = require("multer");
const storage = multer.diskStorage({
destination: (req, file, cb) => {
cb(null, "./images/");
},
filename: (req, file, cb) => {
cb(null, file.originalname);
}
});
const upload = multer({storage: storage});
const getMenu = (req, res) => {
Menu
.find()
.then((menu) => res.status(200).json(menu))
.catch((error) => console.log("Ops"));
}
router.get('/api/menu', getMenu);
router.post("/upload", upload.single("articleImage"), (req, res) => {
console.log("request----------------", req.file) // UNDEFINED
// const image = new Image({
// articleImage: req.file.originalname
// });
// image
// .save()
// .then(() => res.json("Ok"))
// .catch((error) => console.log(error));
})
module.exports = router;
正面形式:
import axios from 'axios';
import React, { useState } from 'react';
const NewAdvertisement = () => {
const [file, setFile] = useState(null);
file && console.log(file.name);
const onSubmit = (e) => {
e.preventDefault();
const fd = new FormData();
fd.append("articleImage", file.name);
console.log("fd", fd);
axios
.post("/upload", fd)
// .then(res => console.log(res))
}
return (
<form
onSubmit = {onSubmit}
encType="multipart/form-data"
>
<input type = "file" filename="articleImage" onChange = {e => setFile(e.target.files[0])}/>
<button type = "submit">Submit</button>
</form>
);
};
export default NewAdvertisement;
I am trying to add a pictire to the MongoDB via Multer and NodeJS.
The Multer storage is created.
The middleware based on Multer called upload is inserted into the POST request.
But when I carry out POST request, req.file is undefined.
What is the reason for that?
routes:
const express = require('express');
const Menu = require("../models/menu");
const Image = require("../models/image");
const router = express.Router();
const multer = require("multer");
const storage = multer.diskStorage({
destination: (req, file, cb) => {
cb(null, "./images/");
},
filename: (req, file, cb) => {
cb(null, file.originalname);
}
});
const upload = multer({storage: storage});
const getMenu = (req, res) => {
Menu
.find()
.then((menu) => res.status(200).json(menu))
.catch((error) => console.log("Ops"));
}
router.get('/api/menu', getMenu);
router.post("/upload", upload.single("articleImage"), (req, res) => {
console.log("request----------------", req.file) // UNDEFINED
// const image = new Image({
// articleImage: req.file.originalname
// });
// image
// .save()
// .then(() => res.json("Ok"))
// .catch((error) => console.log(error));
})
module.exports = router;
front form:
import axios from 'axios';
import React, { useState } from 'react';
const NewAdvertisement = () => {
const [file, setFile] = useState(null);
file && console.log(file.name);
const onSubmit = (e) => {
e.preventDefault();
const fd = new FormData();
fd.append("articleImage", file.name);
console.log("fd", fd);
axios
.post("/upload", fd)
// .then(res => console.log(res))
}
return (
<form
onSubmit = {onSubmit}
encType="multipart/form-data"
>
<input type = "file" filename="articleImage" onChange = {e => setFile(e.target.files[0])}/>
<button type = "submit">Submit</button>
</form>
);
};
export default NewAdvertisement;
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
您仅将文件 name 附加到您的表单上:
但是您必须附加整个文件对象:
You append only the file name to your form:
but you must append the entire file object:
看来您只是发布文件。名称仅是文件的名称而不是二进制数据。检查req.body。章节图,您会得到它
it seems you are only posting file.name which is only name of file not binary data. check req.body.articleImage you will get it