在设备上第二次启动后,Cordova iOS应用程序崩溃了

时间:2018-08-06 19:07:12

标签: ios cordova firebase

经过大量调查,我不知道这里可能是什么问题。我有一个使用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令牌。

1 个答案:

答案 0 :(得分:0)

我有一个非常相似的问题。

我发现问题出在我第二次调用window.FirebasePlugin.grantPermission()时。

进行一项测试,而无需多次征求许可。