我正在使用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>
答案 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
如上所述,客户端功能似乎按预期工作。