我很难过要通过api路由上传文件才能上班。
在客户端上,我以这种方式提交文件:
onFormSubmit = (e) => {
e.preventDefault() // Stop form submit
this.fileUpload(this.state.file).then((response) => {
console.log('rD', response.data)
})
}
onFileChange = (e) => {
this.setState({ file: e.target.files[0] })
}
fileUpload = (file) => {
const url = '/api/mail/upload'
const formData = new FormData()
formData.append('file', file)
const config = {
headers: {
'X-CSRF-TOKEN': this.props.session.csrfToken
}
}
return axios.post(url, formData, config)
}
我对/api/mail/upload
的请求如下所示:
Request Headers:
Accept: application/json, text/plain, */*
Accept-Encoding: gzip, deflate, br
Accept-Language: en-US,en;q=0.9,de-DE;q=0.8,de;q=0.7
Connection: keep-alive
Content-Length: 1331
Content-Type: multipart/form-data; boundary=----WebKitFormBoundaryBlNt6z8t4rGZT0x6
Cookie: abc123
Host: localhost:3000
Origin: http://localhost:3000
Referer: http://localhost:3000/new
Sec-Fetch-Mode: cors
Sec-Fetch-Site: same-origin
User-Agent: Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/79.0.3945.79 Safari/537.36
X-CSRF-TOKEN: abc123
Form Data:
file: (binary)
然后在路由(/ api / mail / upload)中,我试图使用强大的语法来解析表单数据并最终对文件进行处理。
我已经通过在api路由文件的底部添加以下内容来确保禁用内置主体解析器:
export const config = {
api: {
bodyParser: false
}
}
^^那是正确的方法,对吧?
最后,在api路线中,我已经尝试了许多不同的方法,但是目前以下是我希望起作用的方法,但事实并非如此。
module.exports = async (req, res) => {
const form = new formidable.IncomingForm()
form.parse(req, (err, fields, files) => {
if (err) return reject(err)
console.log(fields, files)
res.status(200).json({ fields, files })
})
// if I console.log(form) here - I can see the request details, so it seems to be picking that up
}
[这无论在服务器端还是在客户端都不会产生任何输出,我希望console.log(fields, files)
在服务器端输出文件名,等等。
有人知道我在想什么吗?
我相信,如果您正在端点内部执行异步操作,那么next.js希望您返回一个承诺,例如
export default (req, res) => {
const promise = new Promise((resolve, reject) => {
const form = new formidable.IncomingForm();
form.parse(req, (err, fields, files) => {
if (err) return reject(err);
resolve({fields, files});
})
})
return promise.then(({fields, files}) => {
res.status(200).json({ fields, files })
})
}