本文实例为大家分享了iOS本地推送的具体代码,供大家参考,具体内容如下
首先创建全局的本地通知对象及弹出框
// 弹出本地消息 @property(nonatomic,strong)UILocalNotification *localNotification; @property(nonatomic,strong)UIAlertController *alertcontrol; 其次在代码中实现如下: - (void)application:(UIApplication *)application didReceiveRemoteNotification:(NSDictionary *)userInfo fetchCompletionHandler: (void (^)(UIBackgroundFetchResult))completionHandler { // 判断程序是否在打开状态,即是否在前台运行的状态 if (application.applicationState == UIApplicationStateActive) { // 如果之前已经接受到消息,并且用户未对弹出框进行处理,关闭原来弹出框 if (self.localNotification) { [self.alertcontrol dismissViewControllerAnimated:YES completion:nil]; } [self bulidLocationNotification:application userinfo:userInfo]; }else{ // 判断程序是否未打开状态,即是否在后台运行或关闭状态,极光推送设置角标 if ([application applicationIconBadgeNumber]>0) { [JPUSHService setBadge:[application applicationIconBadgeNumber]]; } } [JPUSHService handleRemoteNotification:userInfo]; NSLog(@"收到通知:%@", [self logDic:userInfo]); completionHandler(UIBackgroundFetchResultNewData); } - (void)application:(UIApplication *)application didReceiveLocalNotification:(UILocalNotification *)notification { // 弹出消息 if (self.localNotification) { self.alertcontrol = [UIAlertController alertControllerWithTitle:@"" message:self.localNotification.alertBody preferredStyle:UIAlertControllerStyleAlert]; UIAlertAction *action = [UIAlertAction actionWithTitle:@"确定" style:UIAlertActionStyleDefault handler:^(UIAlertAction * _Nonnull action) { self.localNotification = nil; self.alertcontrol = nil; }]; [self.alertcontrol addAction:action]; [self.window.rootViewController presentViewController:self.alertcontrol animated:YES completion:nil]; } } // 创建本地推送消息 -(void)bulidLocationNotification:(UIApplication *)application userinfo:(NSDictionary *)userInfo{ self.localNotification = [[UILocalNotification alloc]init]; self.localNotification.fireDate = [NSDate dateWithTimeIntervalSinceNow:1]; self.localNotification.alertBody = [[userInfo objectForKey:@"aps"] objectForKey:@"alert"]; self.localNotification.alertAction = @"确定"; self.localNotification.soundName = @"sound.caf"; self.localNotification.userInfo = userInfo; [application presentLocalNotificationNow:self.localNotification]; }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。
本文向大家介绍iOS本地推送简单实现代码,包括了iOS本地推送简单实现代码的使用技巧和注意事项,需要的朋友参考一下 本文为大家分解介绍了iOS本地推送代码的三步骤,供大家参考,具体内容如下 第一步:创建本地推送 第二步:接收本地推送 第三步:解除本地推送 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持呐喊教程。
客户端关于推送的方法只有两个,它们分别是: Subscribe 方法 Subscribe(name string, id string, settings *InvokeSettings, callback interface{}) (err error) Subscribe 方法的用处是订阅服务器端的推送服务。该方法有两种方式,一种是自动获取设置客户端 id,另一种是手动设置客户端 id。 参数
本文向大家介绍iOS推送之本地通知UILocalNotification,包括了iOS推送之本地通知UILocalNotification的使用技巧和注意事项,需要的朋友参考一下 摘要: Notification是智能手机应用编程中非常常用的一种传递信息的机制,而且可以非常好的节省资源,不用消耗资源来不停地检查信息状态(Pooling),在iOS下应用分为两种不同的Notification种类,本
长连接服务(TCP、WebSocket)支持向客户端推送数据,具体用法https://doc.imiphp.com/utils/Server.html
长连接服务(TCP、WebSocket)支持向客户端推送数据,具体用法https://doc.imiphp.com/utils/Server.html
是否可以在Silverlight中创建代理客户端,这意味着Silverlight应用程序知道代理服务器的主机、端口、用户名和密码,然后建立与代理服务器的连接? 然后,Silverlight应用程序将能够向该代理服务器后面的资源发出HTTP请求。 这样,Silverlight应用程序就可以访问某些资源,而无需首先在客户端计算机上安装第三方代理客户端,因为代理客户端将是Silverlight应用程序本