5

在使用 GCM 和 chrome开发web-push期间。我最近遇到了这个问题(几个小时前一切仍然正常)

我不确定这是否是由于 GCM 的一些变化或云的停机时间而发生的......任何信息将不胜感激。

我的代码

var payload = JSON.stringify({
    title: 'notification title',
    body: 'message body'
});
webPush.sendNotification(params.endpoint, {
    userPublicKey: params.userPublicKey,
    userAuth: params.userAuth,
    payload: payload
}).then(function (res) { 
    // console.log of stuff
})
.catch(function(error){
    console.log(error);
    process.exit(1);
});

痕迹:

{
  WebPushError: Received unexpected response code
  at IncomingMessage.<anonymous> (/var/www/***/pwa/node_modules/web-push /index.js:264:20)
  at emitNone (events.js:91:20)
  at IncomingMessage.emit (events.js:185:7)
  at endReadableNT (_stream_readable.js:926:12)
  at _combinedTickCallback (internal/process/next_tick.js:74:11)
  at process._tickCallback (internal/process/next_tick.js:98:9)
  name: 'WebPushError',
  message: 'Received unexpected response code',
  statusCode: 400,
  headers: {
    'content-type': 'text/plain; charset=UTF-8',
     date: 'Wed, 04 May 2016 11:35:13 GMT',
     expires: 'Wed, 04 May 2016 11:35:13 GMT',
    'cache-control': 'private, max-age=0',
    'x-content-type-options': 'nosniff',
    'x-frame-options': 'SAMEORIGIN',
    'x-xss-protection': '1; mode=block',
     server: 'GSE',
    'alternate-protocol': '443:quic',
    'alt-svc': 'quic=":443"; ma=2592000; v="33,32,31,30,29,28,27,26,25"',
    'accept-ranges': 'none',
     vary: 'Accept-Encoding',
     connection: 'close'
  },
  body: 'JSON_PARSING_ERROR: Unexpected token END OF FILE at position 467.\n' 
}
4

2 回答 2

2

@Lihn,将您的有效负载粘贴到此处。从错误消息来看,您似乎正在发送格式错误的 json 消息。

您可以使用此服务检查 json 中的语法问题。

GCM 文档指出状态代码 400 表示无法解析 json 消息。

于 2016-05-04T13:03:42.440 回答
1

如果您尝试使用 web-push 发送推送通知,请尝试使用 #npm run web-push generate-vapid-keys 重新生成公钥和私钥。通过更换这些键再试一次。祝你好运。

于 2018-02-28T06:39:36.073 回答