我正在尝试解析从服务器端发送的$.ajax()
和在服务器端发送的多部分/表单数据,数据req.body
未req.files
按照 express 文档中的说明传入。
我想要做的是通过发送多个图像文件和表单数据$.ajax
,然后在服务器端接收它并通过nodemailer将这些图像作为附件发送,所以要通过nodemailer发送它我需要能够阅读,我get 只是 req.body 中的数据垃圾,我什至无法阅读。代码如下。
客户端 Ajax 请求发送功能:-
$('.contact-button').on('click', function(e) {
e.preventDefault();
var data = new FormData();
var filesList = document.getElementById('files');
for (var i = 0; i< filesList.files.length; i ++) {
data.append('file', filesList.files[i]);
}
data.append('messageData', $('#contact-form').serialize());
$.ajax({
url: '/api/contactus/',
data: data,
processData: false,
type: "POST",
contentType: 'multipart/form-data',
mimeType: 'multipart/form-data',
success: function (data) {
console.log("SUCCESS IN AJAX");
console.dir(data);
},
error: function (err) {
console.log('error in AJAX');
console.log(err);
}
});
});
处理请求的服务器端 API:-
function contactUs (req, res, next) {
console.log("TESTING Body ");
console.dir(req.body);
console.log("TESTING Files");
console.dir(req.files);
var Transport = email.createTransport("SMTP", {
service: "Gmail",
auth: {
user: "dummy@dummy.com",
pass: "dumy1234"
}
});
Transport.sendMail({
host : "smtp.gmail.com",
port : "587",
domain : "domain.com",
to : "dummy@dummy.com",
from : "dummy@dummy.com",
subject : "[Technical Support] "+EmailInfo.Name + " Submitted an Issue!",
reply_to: req.body.Email,
html : "<h2 >Message Details</h2>",
authentication : "login",
username: 'dummy@dummy.com',
password: 'dumy1234'
}, function (err, result) {
if (err) {
next('email sending failed', err);
} else {
res.json('email sending Success');
}
});
}
所以这两个问题是如何解析来自ajax请求的多部分数据。?第二如何通过nodemailer将多部分数据作为附件发送。?
请记住,我已经尝试使用app.use(express.multipart());
,但是当我将它插入到我的 app.js 中时,它给了我400 bad request
,甚至没有执行该contactUs
功能。