- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我也在开发者论坛上问过这个问题,但由于我的时间不多了,我希望在 stackoverflow 上发帖可以更快。
目前我能够接收推送通知,并且我想发送一些额外的数据,经过搜索后我得出结论,这应该是可能的。这个想法是在触发推送通知时设置来自用户收件箱(在应用程序中)的消息,因此用户会收到一条显示“新消息”的推送通知,并且随之而来的是以不同 key 发送的消息,即当调用推送通知callback
函数时,应该保存在Applications.Properties
中。
但是,回调
函数永远不会被触发。通知已发送,徽章设置为我的 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';
}
}`
最佳答案
问题已解决,
JSON 似乎出了问题,但仍不确定是什么。
在 App.js 中:var data = JSON.parse(e.data);
删除 JSON.parse()
后代码就可以工作了。由于某种原因,JSON 数据不需要解析。因此该行变为 var data = e.data;
关于callback - 钛移动推送通知回调未触发,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14214525/
在我的上一个项目中,我使用了 rxJava,我意识到 observable.doOnError('onErrorCallback').subscribe(action) 和 observable.su
我是一名 C++ 初学者,我认为要真正学习指针和引用,我应该尝试创建一个回调函数,这是我在 JavaScript 中认为理所当然的事情。 但是,对于我的一生,我不知道为什么这些括号在 (*callba
我在库中有一个类,它具有在事件发生时执行的“onMessage”方法。 OnMessage 在执行时需要调用属于主应用程序中的类的“回调”方法。我假设这将通过构造函数完成,但我不知道它是如何实现的。
两者的 jQuery 文档基本上说明了相同的事情,所以我想知道两者之间是否有任何重大差异(如果有的话)。谢谢! 最佳答案 这方面的文档实际上非常糟糕,所以这是我在 studying the sourc
这个问题在这里已经有了答案: Using &&'s short-circuiting as an if statement? (6 个答案) Omitting the second expressi
我正在尝试在 golang 中定义一个回调: package main func main() { x, y := "old x ", "old y" callback
我有一个页面,其中包含从 Google 电子表格生成的许多图表。 典型代码如下所示: var url = "http://my.googlespreadsheet.com/tq?argumentshe
当我运行 linter 时,它显示: subscribe is deprecated: Use an observer instead of an error callback 代码来自 this a
对于异步套接字 // accept ... listener.BeginAccept( new AsyncCallback(AcceptCallback), listener); // listene
我希望能够根据在前面的函数中调用的是 callback(true) 还是 callback(false) 在回调函数中执行一些逻辑。 示例: foo.doFunction = function (pa
从 jQuery.scrollTo.js 库中看到这个 block (在 v1.4 的第 184 行)。 function animate( callback ){ $elem.animate
我正在尝试在我的应用中使用一些回调,它与 "callback(value)" 和 "callback.invoke(value)" 一起工作正确调用回调。 我想知道“回调(值)”是否只是一个缩短版本,
我决定从 keras 切换到 tf.keras(建议使用 here)。因此我安装了 tf.__version__=2.0.0和 tf.keras.__version__=2.2.4-tf .在我的旧版
我认为这实际上可能会回答我关于 Stack Overflow 的另一个问题如果我能确认这一点。 返回回调和只调用回调有什么区别? 我看到代码执行其中之一/或/两者,并试图思考为什么以及何时执行哪个。
我目前正在学习 Rust 并希望用它来开发 GUI基于 GTK+ 的应用程序。我的问题与注册回调有关在这些回调中响应 GTK 事件/信号和变异状态。我有一个有效但不优雅的解决方案,所以我想问一下是否有
我在回调函数中传递参数时遇到问题。我使用 redux-form,当我更改 SkinList 中的选择时,它会触发 onChange 回调 - activeSkinChange 方法 在activeSk
我有 8 个相互依赖的回调。我的想法是要有一个更具可读性的过程,但我不明白如何处理这个问题。 我的回调 hell 的一个例子是: return new Promise(function (resolv
因此,我的函数接受一个值和任意数量的回调作为参数(我应该使用扩散操作符吗?)该函数应该返回通过所有给定回调传递该值的最终结果。。我返回的“CB2(Res1)”不是一个函数。如何将第一个回调的结果传递给
在谈到 future 和回调时,documentation说是 The Vert.x core APIs are based on callbacks to notify of asynchronou
我开始觉得自己很蠢。我正在关注 Facebook-Connect 演示“The Run Around”。 当我导航到 http://www.[mysite].com/testing/register_
我是一名优秀的程序员,十分优秀!