我的 Express 应用程序遇到了这个非常奇怪的问题,我只想访问通过表单数据通过发布请求发送的 req.body 数据,但不幸的是,当我尝试访问 request.body 中的这些值时,我收到未定义的错误,但是什么是奇怪的是,如果我使用 multer 中间件(我在另一条路线上使用它来上传文件),我不会收到此错误。
我已经配置了express提供的默认主体解析器。
//body pharser
app.use(express.json());
app.use(
express.urlencoded({
extended: true,
})
);
//multer configuration
const ImageUpload = multer({
storage: storage,
limits: { fileSize: 4194304 },
fileFilter: Imagfilter,
});
//this will return undefined
app.post("/available",(req, res) => {
console.log(req.body.name);
}
//but this will return the value without any issues
app.post(
"/available",
ImageUpload.fields([
{ name: "nicImageFront", maxCount: 1 },
{ name: "nicImageBack", maxCount: 1 },
]),
(req, res) => {
console.log(req.body.name);
}
这没什么奇怪的。
FormData https://developer.mozilla.org/en-US/docs/Web/API/FormData对象生成多部分请求。他们必须这样做,这就是他们支持文件上传的方式。
FormData 接口提供了一种轻松构造一组表示表单字段及其值的键/值对的方法,然后可以使用 XMLHttpRequest.send() 方法轻松发送这些键/值对。如果编码类型设置为“multipart/form-data”,它使用的格式与表单使用的格式相同。
Multer 旨在解析多部分请求。
The urlencoded
中间件旨在解析 urlencoded 请求,而不是多部分请求。
The json
中间件旨在解析 JSON 编码的请求,而不是多部分请求。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)