[英]Sending data using post method via fetch returns an empty object
这是我用于click
事件的addEventListener
函数
export const showTicket = async function() {
try {
// GETTING USER DATA
const response = await fetch("/api/v1/users/me");
const data = await response.json();
//
const user = data.data.data;
// CREATING VISITOR
const visitor = {
VisitorNumber: user.visitorId,
FirstName: user.firstName,
LastName: user.lastName,
Company: user.company,
JobTitle: user.profile,
Email: user.email,
Mobile: user.mobile,
Nationality: user.nationality,
Country: user.country,
Category: user.type,
};
// SENDING VISITOR OBJECT TO ANOTHER API
const url = "/api/v1/eticket/visitor";
const options = {
method: "POST",
header: {
"Content-Type": "application/json",
},
body: JSON.stringify(visitor),
};
if (!user.eventId) {
const response1 = await fetch(url, options);
const data1 = await response1.json();
}
const ticketMarkup = `<div class="ticket">
<div class="ticket__logo"> <img src="/images/vp-expo-logo.png"> </div>
<div class="ticket__data">
<p>Your ticket is ready to be printed</p>
</div>
<button class="btn ticket__print-ticket" data-visitor-id=${user.visitorId}> Print Ticket </button>
<button class="btn update-data"> Update Data </button>
</div>
`;
showPopup(ticketMarkup);
} catch (err) {
console.log(err);
}
};
所以首先我从 api '/api/v1/users/me' 获取用户详细信息,它工作正常,我能够检索数据,并使用用户属性创建一个变量 'Visitor'。
然后我必须将访问者变量作为正文发送到另一个 api ('/api/v1/eticket/visitor') 以便它可以接收正文作为 req.body
但是在“/api/v1/eticket/visitor”上,req.body 显示为一个空对象。
这是这个接收api的控制器的开放部分('/api/v1/eticket/visitor')
exports.addOneVisitor = async function(req, res, next) {
try {
const visitor = req.body;
console.log(req.body);
请告知我做错了什么?
有史以来最愚蠢的错误!!...但我一直在重复这个错误。 我正在回答我自己的问题,以提醒我(以及那些反复犯相同错别字的人!)..
当您为获取请求编写选项部分时,它是headers
而不是header
。
希望这可以帮助某人不要因为缺少“s”而失去 2 天的生命
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.