经过大量调查,我不知道这里可能是什么问题。我有一个使用cordova开发的iOS应用,并使用Firebase(cordova-plugin-firebase)进行通知。
当我第一次使用Xcode在我的设备上运行我的应用程序时,一切正常,通知到达并且该应用程序运行良好。当我停止Xcode上的应用程序并尝试在不使用Xcode的设备上打开它时,问题就开始了,该应用程序在启动屏幕上崩溃了。如果我发送任何通知,它都不会出现问题,但是当我打开一个通知时,该应用程序再次在启动屏幕上崩溃。
我已经在Apple开发者帐户上创建了所有证书以及开发,生产和临时配置文件,创建了APNs Key并将其存储在Firebase帐户中,我的Resources文件夹中有GoogleService-Info.plist文件(平台/ ios / AppName /资源和平台/ ios / AppName /资源/资源)。
我在日志中看到的唯一错误是这个
无法连接到FCM。错误Domain = com.google.fcm代码= 2001“ FIRMessaging已连接”
还有这个
对象不响应-messaging:didReceiveRegistrationToken :,也不响应-messaging:didRefreshRegistrationToken:。请实现-messaging:didReceiveRegistrationToken:并随附FCM令牌。
当我接受通知权限提示框时,将显示此错误。
这是我的用于处理通知的JS:
function firebasePUSH() {
if (device.platform === "iOS") {
window.FirebasePlugin.hasPermission(function (data) {
if (!data.isEnabled) {
window.FirebasePlugin.grantPermission();
}
});
}
window.FirebasePlugin.onNotificationOpen(function (notification) {
console.log("tipo de notificacion " + notification.tipo);
console.log(notification);
if (notification.tipo === "alerta") {
var parametros = {
id: notification.numero,
categoria: "rescato"
};
myApp.request.post("http://190.98.210.41/comuna/app/contactos.php", parametros, function (data) {
var json = JSON.parse(data);
console.log(json);
if (json.error === false) {
mostrarSOS(json.alerta);
}
});
} else if (notification.tipo === "chat" || notification.tipo === "salud" || notification.tipo === "seguridad" || notification.tipo === "contacto" || notification.tipo === "oficina") {
aceptarLlamada();
} else if (notification.tipo === "publicidad") {
mostrarPublicidad(notification.numero);
} else if (notification.tipo === "sondeo") {
mostrarSondeo(notification.numero);
}
}, function (error) {
console.error("onResume>>" + error);
});
window.FirebasePlugin.getToken(function (token) {
try {
var jsonToken = JSON.parse(token);
token = jsonToken.token;
console.warn("venia json: " + jsonToken.token);
}
catch (err) {
console.warn("viene json limpio: " + token);
}
console.log("getToken js: " + token);
localStorage.setItem('registrationId', token);
/*PEGRUNTA SI YA ESTA LOGEADO*/
if (localStorage.getItem("correo") !== null && localStorage.getItem("clave") !== null) {
//pasa a la pantalla principal
var parametros = {
"id": localStorage.getItem("id"),
"token": localStorage.getItem('registrationId'),
"categoria": "token",
format: "json",
callback: function () {
return true;
}
};
myApp.request.json("http://190.98.210.41/comuna/app/usuario_get.php", parametros, function (data) {
console.log(data);
}, function (error) {
console.log(error);
});
}
}, function (error) {
console.error("getToken error: " + error);
});
window.FirebasePlugin.onTokenRefresh(function (token) {
try {
var jsonToken = JSON.parse(token);
token = jsonToken.token;
console.warn("token json: " + jsonToken.token);
}
catch (err) {
console.warn("token limpio: " + token);
}
console.log("onTokenRefresh js: " + token);
localStorage.setItem('registrationId', token);
/*PEGRUNTA SI YA ESTA LOGEADO*/
if (localStorage.getItem("correo") != null && localStorage.getItem("clave") != null) {
//pasa a la pantalla principal
var parametros = {
"id": localStorage.getItem("id"),
"token": localStorage.getItem('registrationId'),
"categoria": "token",
format: "json",
callback: function () {
return true;
}
};
myApp.request.json("http://190.98.210.41/comuna/app/usuario_get.php", parametros, function (data) {
console.log(data);
}, function (error) {
console.log(error);
});
}
}, function (error) {
console.error(error);
});
}
在这个问题上我可以使用一些帮助,因为我已经处理了好几个星期了,我感到非常沮丧。非常感谢你们。
编辑:
启动应用程序时发现第三个错误。
[Firebase / Messaging] [I-FCM002023]对象不响应-messaging:didReceiveRegistrationToken :,也不响应-messaging:didRefreshRegistrationToken:。请实现-messaging:didReceiveRegistrationToken:并随附FCM令牌。
答案 0 :(得分:0)
我有一个非常相似的问题。
我发现问题出在我第二次调用window.FirebasePlugin.grantPermission()时。
进行一项测试,而无需多次征求许可。