【发布时间】:2019-08-10 13:32:17
【问题描述】:
我正在尝试实现一个 Android 订购系统,并且我正在使用实时数据库。为了发送通知,我在 JavaScript 中使用 Firebase 函数。
每个用户连同他们的 ID、发送通知的令牌以及其他数据一起存储在数据库中。 我要做的是检测用户何时收到订单并向他们发送通知。
问题出现在这里。 在某些情况下会发送通知,而在其他情况下则不会。查看我的“sendNotif”函数的日志,我发现错误是这样的:
TypeError: Cannot read property 'idcomprador' of null
at exports.sendNotif.functions.database.ref.onWrite (/user_code/index.js:133:32)
at Object.<anonymous> (/user_code/node_modules/firebase-functions/lib/cloud-functions.js:112:27)
at next (native)
at /user_code/node_modules/firebase-functions/lib/cloud-functions.js:28:71
at __awaiter (/user_code/node_modules/firebase-functions/lib/cloud-functions.js:24:12)
at cloudFunction (/user_code/node_modules/firebase-functions/lib/cloud-functions.js:82:36)
at /var/tmp/worker/worker.js:827:24
at process._tickDomainCallback (internal/process/next_tick.js:135:7)
我的代码:
exports.sendNotif = functions.database.ref('/Usuarios/{vendedorId}/Solicitudes/Venta/{pushId}').onWrite((change, context) => {
// Grab the current value of what was written to the Realtime Database.
const solicitud = change.after.val();
const compradorId = solicitud.idcomprador
const pedidoId = solicitud.idpedido
const vendedorId = solicitud.idvendedor
var solicitudTokens = [vendedorId];
// Notification details.
const payload = {
notification: {
title: `Order`,
body: `order`,
icon: 'photoURL',
tag: 'solicitudventa',
sound: 'default',
clickAction: 'ACTIVITY_ORDER',
badge: '2'
},
data: {
extra: 'extra_data',
},
};
const options = {
collapseKey: 'demo',
contentAvailable: true,
priority: 'high',
timeToLive: 60 * 60 * 24,
};
var ref = admin.database().ref(`Usuarios/${vendedorId}/token/result/token`);
return ref.once("value", function(snapshot){
admin.messaging().sendToDevice(snapshot.val(), payload)
},
function (errorObject) {
console.log("The read failed: " + errorObject.code);
});
});
第 133 行是这样的:const compradorId = solicitud.idcomprador。 我不明白为什么它有时有效,有时无效。
【问题讨论】:
标签: javascript firebase firebase-realtime-database firebase-cloud-messaging google-cloud-functions