我试图向我的服务器发送一个新的推送订阅,但遇到了一个错误“Uncaught (in promise) SyntaxError: Unexpected end of JSON input”,控制台显示在我的索引页第1行,显然不是这种情况。 我怀疑出现问题的函数(因为当我将其注释掉时不会抛出错误)是
sendSubscriptionToBackEnd(subscription)
,它在以下位置被调用:function updateSubscriptionOnServer(subscription) {
const subscriptionJson = document.querySelector('.js-subscription-json');
const subscriptionDetails = document.querySelector('.js-subscription-details');
if (subscription) {
subscriptionJson.textContent = JSON.stringify(subscription);
sendSubscriptionToBackEnd(subscription);
subscriptionDetails.classList.remove('is-invisible');
} else {
subscriptionDetails.classList.add('is-invisible');
}
}
该函数本身(在上述函数之前):
function sendSubscriptionToBackEnd(subscription) {
return fetch('/path/to/app/savesub.php', {
method: 'POST',
headers: {
'Content-Type': 'application/json'
},
body: JSON.stringify(subscription)
})
.then(function(response) {
if (!response.ok) {
throw new Error('Bad status code from server.');
}
return response.json();
})
.then(function(responseData) {
if (!(responseData.data && responseData.data.success)) {
throw new Error('Bad response from server.');
}
});
}
我已经尝试将fetch调用中的单引号替换为双引号,但结果相同。
我知道JSON应该被填充,因为它在updateSubscriptionOnServer()
函数中打印到屏幕上,使用subscriptionJson.textContent = JSON.stringify(subscription);
,并且我在google codelab的示例服务器中使用了该输出以成功接收推送。
编辑:这是JSON作为字符串,但我没有看到语法错误:
{"endpoint":"https://fcm.googleapis.com/fcm/send/dLmthm1wZuc:APA91bGULRezL7SzZKywF2wiS50hXNaLqjJxJ869y8wiWLA3Y_1pHqTI458VIhJZkyOsRMO2xBS77erpmKUp-Tg0sMkYHkuUJCI8wEid1jMESeO2ExjNhNC9OS1DQT2j05BaRgckFbCN","keys":{"p256dh":"BBz2c7S5uiKR-SE2fYJrjPaxuAiFiLogxsJbl8S1A_fQrOEH4_LQjp8qocIxOFEicpcf4PHZksAtA8zKJG9pMzs=","auth":"VOHh5P-1ZTupRXTMs4VhlQ=="}}
有什么想法吗??
JSON.stringify()
而不是JSON.parse()
? - alex kucksdorf