5

私は開発者フォーラムでもこの質問をしましたが、時間がなくなったので、stackoverflowへの投稿がもっと早くなることを望んでいました。

現在、プッシュ通知を受信することができ、追加のデータを送信したいのですが、周りを検索した後、これは可能であると結論付けました。プッシュ通知が発行されたときに(アプリ内の)ユーザーの受信トレイからメッセージを設定するという考え方です。これにより、ユーザーは「新しいメッセージ」というプッシュ通知を受け取り、それとともに別のキーで送信されるメッセージが送信されます。Applications.Propertiesプッシュ通知callback機能が呼び出されたときに保存されることになっています。

ただし、callback関数がトリガーされることはありません。通知が送信され、バッジは私のphpスクリプトが行うメッセージに設定されます。コールバックがトリガーされたかどうかをテストするために、バッジとメッセージをハードコードされた値に変更しました(以下を参照)。このコードは主にios muncherから取得しましたが、のアラートcallbackはユーザーに表示されるものであると想定しました。

私が気付いた別のことは、ユーザーがアプリを使用していないとき、つまりアプリがバックグラウンドで実行されているときにのみプッシュ通知を受信することです。ユーザーがアプリのプッシュ通知を使用している場合は表示されませんが、これはコールバックがトリガーされていないことが原因である可能性があります。

よろしくお願いします。

いくつかのコードの下:

Titanium.Network.registerForPushNotifications({  
    types: [  
            Titanium.Network.NOTIFICATION_TYPE_BADGE,  
            Titanium.Network.NOTIFICATION_TYPE_ALERT,
            Titanium.Network.NOTIFICATION_TYPE_SOUND  
        ],  
        success:function(e){
            var deviceToken = e.deviceToken;  
            Ti.API.info("Push notification device token is: "+deviceToken);  

            //alert('device token is' +e.deviceToken);  
            var request = Titanium.Network.createHTTPClient();

            request.open("POST","http://*********/sendToken.php");  
            var params = {  
                "token": e.deviceToken,
                "username": authProperties[0].username,
                "userId": authProperties[0].userId    
            };  

            request.send(params);

            Ti.API.info("Push notification types:         "+Titanium.Network.remoteNotificationTypes);  
    Ti.API.info("Push notification enabled:"+Titanium.Network.remoteNotificationsEnabled);  
},  
error:function(e){
    alert("Error during registration: "+e.error);

    Ti.API.info("Error during registration: "+e.error);  
},
callback:function(e)  
{  
    // called when a push notification is received.  
    //Titanium.Media.vibrate();  
    var data = JSON.parse(e.data);

    request.open("POST","http://*********/callback.php");  
    var params = {  
        "token": e.deviceToken,
        "username": authProperties[0].username,
        "userId": authProperties[0].userId    
    };  

    request.send(params);

    //  Message data for the inbox
    var inboxData = data.inbox;     

    Titanium.App.properties.setString("badgeCount",data.badge);

    var badge = data.badge;  
    if(badge > 0){  
        Titanium.UI.iPhone.appBadge = 202;//badge;  
    }  

    var message = data.message;
    if(message != ''){  
        var my_alert=Ti.UI.createAlertDialog({title:'',message:JSON.stringify(inboxData) });

        my_alert.show();  
    }  
}  
});

次のスクリプトは、プッシュ通知のphp部分を処理します。

$serverId = "81273";  
    $name = "APNS";  
    $apnsPort = 2195;//5223;  
    $passPhrase = "";  
    $fwrite = "";  
    $sslUrl = "ssl://gateway.push.apple.com:" . $apnsPort;  
    $apnsCert = "./apns-distr.pem";//give the apns.pem file path on your server  
    $badge = 22;
$message = "[". date("d-m-Y h:i:s") . '] Er is een nieuw bericht voor u.';  
$inboxArray = array();
$inboxArray["id"]= 1;
$inboxArray["message"] = "Dit bericht dient als test";
$inboxArray["date"] = date("d-m-Y h:i:s");
$apnspayload['aps'] = array ('alert' => $message,'badge' => $badge,'sound' => 'default', 'inbox' => $inboxArray);  

$payload = json_encode($apnspayload);  

$tokens = array();
$tokens[] = "********** ** * * *";

foreach($tokens as $tokenId){


    $apnsMessage = chr(1) . pack('N', time()) . pack('N', time() + 86400) . chr(0) . chr(32) 
        . pack('H*', str_replace(' ', '', $tokenId)) . chr(0) . chr(strlen($payload)) . $payload;  

    $streamContext = stream_context_create();  

    stream_context_set_option($streamContext, 'ssl', 'local_cert', $apnsCert);  
    stream_context_set_option($streamContext, 'ssl', 'passphrase', $passPhrase);  

    $apns = stream_socket_client($sslUrl, $error, $errorString, 6, STREAM_CLIENT_CONNECT, $streamContext);  

    if($apns){  
        $fwrite = fwrite($apns, $apnsMessage);  

        fclose($apns);  
        @socket_close($apns);  
    }else{  
        echo 'request failed';  
    }  
}`
4

1 に答える 1

2

問題が解決しました、

JSONの問題が発生したようですが、それでも何が原因かわかりません。

App.jsの場合: コードvar data = JSON.parse(e.data);を削除するJSON.parse()と機能しました。何らかの理由で、JSONデータを解析する必要はありませんでした。したがって、行は次のようになりました。var data = e.data;

于 2013-01-22T10:54:50.267 に答える