Cordova Push Notifications (PhoneGap PushPlugin) 不触发 ecb 回调



我正在将Cordova推送通知插件1.3.4与我的Cordova/Phonegap应用程序一起使用。 不幸的是,当收到推送通知时,我的JavaScript中的ecb回调永远不会被触发,我无法处理推送通知(即使应用程序在前台运行时也是如此)。

我正在使用演示中的示例代码:

pushNotification.register(tokenHandler, errorHandler, {"badge": "true", "sound": "true", "alert": "true", "ecb": "onNotificationAPN"});

注册成功,但从不触发以下回调:

function onNotificationAPN (event) {
    if (event.alert)
    {
        navigator.notification.alert(event.alert);
    }
 }

问题在于您定义回调函数的方式,导致推送插件对回调的评估(即通过 [webView stringByEvaluatingJavaScriptFromString )失败,因为它不会意识到它。

如果您将回调函数定义为全局对象,则每次收到新通知时,插件都会正确触发回调:

onNotificationAPN = function(event) {
    if (event.alert)
    {
        navigator.notification.alert(event.alert);
    };
};

对于 Android,您将以相同的方式定义onNotificationGCM回调。

移动娱乐的答案为我解决了这个问题! 我整个下午都在寻找解决方案,尽管是 GCM 回调,但功能是相同的。

我会投票给移动娱乐,但我是新来的,它不会让我,但谢谢!

对于任何可能正在寻找GCM解决方案的人(Googleverse中有很多没有很多好的答案),这是我的代码最终起作用了:

// handle GCM notifications for Android 
            onNotificationGCM = function(e){
                alert('onGCM');
                switch( e.event )
                {
                    case 'registered':
                        if ( e.regid.length > 0 )
                        {
                            console.log("Regid " + e.regid);
                            //Do registration work here...
                        }
                    break;
                    case 'message':
                      // this is the actual push notification. its format depends on the data model from the push server
                      alert('message = '+e.message+' msgcnt = '+e.msgcnt);
                    break;
                    case 'error':
                      alert('GCM error = '+e.msg);
                    break;
                    default:
                      alert('An unknown GCM event has occurred');
                      break;
                }
            }     

如果您与 azure push 一起使用..以下是工作代码。(用于电话间隙的推送插件)

    function InitpushNotificaions() {
      //  alert("Notification setup");
        try {

            mobileServiceClient = new WindowsAzure.MobileServiceClient('https://mobbacktest.azure-mobile.net/', 'RvahPxHKoEsGiLdlCYZpHBllvSVQxl66');
            pushNotification = window.plugins.pushNotification;
            if (device.platform == 'android' || device.platform == 'Android' ||
                    device.platform == 'amazon-fireos')
            {
                // AndroId
                pushNotification.register(successHandler, errorHandler, { "senderID": "724086851305", "ecb": "onNotification" });       // required!
            }
            else
            {
                //IOS
                pushNotification.register(tokenHandler, errorHandler, { "badge": "true", "sound": "true", "alert": "true", "ecb": "onNotificationAPN" });   // required!
            }
        }
        catch (err) {
            txt = "There was an error on this page.nn";
            txt += "Error description: " + err.message + "nn";
            alert(txt);
        }


    }

    // handle APNS notifications for iOS
 onNotificationAPN=function (e) {
        if (e.alert) {
            $("#app-status-ul").append('<li>push-notification: ' + e.alert + '</li>');
            // showing an alert also requires the org.apache.cordova.dialogs plugin
            navigator.notification.alert(e.alert);
        }
        if (e.sound) {
            // playing a sound also requires the org.apache.cordova.media plugin
            var snd = new Media(e.sound);
            snd.play();
        }
        if (e.badge) {
            pushNotification.setApplicationIconBadgeNumber(successHandler, e.badge);
        }
    }
    //handle GCM notifications for Android
    onNotification = function (e) {
       // alert("gcm");
        switch (e.event) {
            case 'registered':
                if (e.regid.length > 0) {
                    // Your GCM push server needs to know the regID before it can push to this device
                    // here is where you might want to send it the regID for later use.
                   // alert('step 1 Azure! ' + e.regid);
                    if (mobileServiceClient) {
                       // alert('step 2 Azure!');
                        // Template registration.
                        var template = "{ "data" : {"message":"$(message)"}}";
                        // Register for notifications.
                        mobileServiceClient.push.gcm.registerTemplate(e.regid,
                          "myTemplate", template, null)
                          .done(function () {
                           //   alert('Registered template with Azure!');
                          }).fail(function (error) {
                              //alert('Failed registering with Azure: ' + error);
                          });
                    }

                    console.log("regID = " + e.regid);
                }
                break;
            case 'message':
                // if this flag is set, this notification happened while we were in the foreground.
                // you might want to play a sound to get the user's attention, throw up a dialog, etc.
                if (e.foreground) {
                    // on Android soundname is outside the payload. 
                    // On Amazon FireOS all custom attributes are contained within payload
                    var soundfile = e.soundname || e.payload.sound;
                    // if the notification contains a soundname, play it.
                    // playing a sound also requires the org.apache.cordova.media plugin
                    var my_media = new Media("/res/" + beep.wav);
                    alert("Message:"+e.message);
                    my_media.play();
                }
                else {  // otherwise we were launched because the user touched a notification in the notification tray.
                    if (e.coldstart) {
                    }
                    else {
                    }
                }

                break;
            case 'error':
                break;
            default:
                break;
        }
    }

    function tokenHandler(result)
    {
       // $("#app-status-ul").append('<li>token: '+ result +'</li>');
        // Your iOS push server needs to know the token before it can push to this device
        // here is where you might want to send it the token for later use.
    }
    function successHandler(result) {
        alert("Success handler:" + result);
     //   $("#app-status-ul").append('<li>success:'+ result +'</li>');
    }
    function errorHandler(error) {
        alert("Error handler:" + error);
    }

相关内容

  • 没有找到相关文章

最新更新