推送api通知不在Android模拟器以及浏览器上工作

时间:2013-10-12 16:15:54

标签: php android pusher

我正在使用Pusher API进行通知,但它适用于我。我在我的网站上有组合框,在这个组合框中部署在azure上,当用户在组合框中更改状态时,三个状态显示待完成请求超时,因此ajax请求将发送到json文件,其中我添加了通道和事件绑定。

我也在模拟器上收到消息

10-12 12:13:15.544: D/CordovaLog(1257): file:///android_asset/www/index.html: Line 28 : Pusher : State changed : unavailable -> connected
10-12 12:13:15.544: I/Web Console(1257): Pusher : State changed : unavailable -> connected at file:///android_asset/www/index.html:28
10-12 12:13:15.553: D/CordovaLog(1257): file:///android_asset/www/index.html: Line 28 : Pusher : Event sent : {"event":"pusher:subscribe","data":{"channel":"dispatcher_channel"}}
10-12 12:13:15.553: I/Web Console(1257): Pusher : Event sent : {"event":"pusher:subscribe","data":{"channel":"dispatcher_channel"}} at file:///android_asset/www/index.html:28
10-12 12:13:17.613: D/CordovaLog(1257): file:///android_asset/www/index.html: Line 28 : Pusher : Event recd : {"event":"pusher_internal:subscription_succeeded","data":{},"channel":"dispatcher_channel"}
10-12 12:13:17.613: I/Web Console(1257): Pusher : Event recd : {"event":"pusher_internal:subscription_succeeded","data":{},"channel":"dispatcher_channel"} at file:///android_asset/www/index.html:28
10-12 12:13:17.623: D/CordovaLog(1257): file:///android_asset/www/index.html: Line 28 : Pusher : No callbacks on dispatcher_channel for pusher:subscription_succeeded
10-12 12:13:17.623: I/Web Console(1257): Pusher : No callbacks on dispatcher_channel for pusher:subscription_succeeded at file:///android_asset/www/index.html:28

json.php这是天蓝色的

function updateRequestStatus($params)
    {
        global $api;

        $params = json_decode($params, true);

        $requestStatus = PageHelper::sanitizeInput($params['requestStatus'], FILTER_SANITIZE_STRING);
        $requestID = PageHelper::sanitizeInput($params['requestID'], FILTER_SANITIZE_NUMBER_INT);

        if(strtolower($requestStatus) == "completed")
        {
            $message = "User Response Has been Sent ";
            $pusher = new Pusher( APP_KEY, APP_SECRET, APP_ID );
            $data = array('message' => $message);
            $pusher->trigger( 'dispatcher_channel', 'dispatcher_Response', $data );
        }

        return $api->updateRequestStatus($requestStatus, $requestID);
    }

以及我在android上使用的index.html。

<!DOCTYPE HTML>
<html>
<head>
<title></title>

<meta name="viewport" content="width=device-width,initial-scale=1"/>

<!--  JavaScript -->


<script src="http://js.pusher.com/2.1/pusher.min.js" type="text/javascript"></script>
<script src="js/cordova.js" type="text/javascript"></script>

<script type="text/javascript">
    // Enable pusher logging - don't include this in production
    Pusher.log = function(message) {
      if (window.console && window.console.log) {
        window.console.log(message);
      }
    };

    var pusher = new Pusher('APP_KEY');
    var channel = pusher.subscribe('dispatcher_channel');
    channel.bind('notification', function(data) {
    setTimeout('getNotification()', 1000);
    channel.bind('dispatcher_Response', function(data) {}); 
    }); 
    function getNotification()
    {
        navigator.notification.alert("status changed", function() {});
    }
  </script>

</head>
</body>
</html>

1 个答案:

答案 0 :(得分:0)

日志显示您已连接并订阅了dispatcher_channel频道。

当您运行json.php时,Pusher Debug Console会显示什么?请参阅:http://pusher.com/docs/debugging#pusher_debug_console

是否显示json.php到达Pusher的消息?

如果没有,那么你应该看看调试PHP代码。看到: https://github.com/pusher/pusher-php-server#debugging

如上所述,客户端功能似乎按预期工作。