ios如何实现推送通知
推送通知的步骤:1、询问是否允许推送通知。2、如果用户允许在APPDELEGATE 中实现
- (void)application:(UIApplication *)application didRegisterForRemoteNotificationsWithDeviceToken:(NSData*)deviceToken{
}
3、将token发送到服务器上
4、服务器收到toke后 发送推送通知,客户端相应该推送同通知
代码如下:
- //每次唤醒
- - (void)applicationDidBecomeActive:(UIApplication *)application
- {
- /*
- Restart any tasks that were paused (or not yet started) while the application was inactive. If the application was previously in the background, optionally refresh the user interface.
- */
- //每次醒来都需要去判断是否得到device token
- [NSTimer scheduledTimerWithTimeInterval:0.5 target:self selector:@selector(registerForRemoteNotificationToGetToken) userInfo:nil repeats:NO];
- //hide the badge
- application.applicationIconBadgeNumber = 0;
- [[CheckVersion sharedCVInstance] checkVersionOfServer];
- [[AnalyticsUtil sharedAnalyticsUtil] appLaunch];
- AnalyticsJSONElement *viewElement = [[AnalyticsJSONElement alloc] init];
- viewElement.jsonType = AnalyticsJSONTypeView;
- viewElement.typeID = @"0";
- [[AnalyticsUtil sharedAnalyticsUtil] postAnalyticsMsgToServerWithElement:viewElement];
- [viewElement release];
- }
- - (void)applicationWillTerminate:(UIApplication *)application
- {
- /*
- Called when the application is about to terminate.
- Save data if appropriate.
- See also applicationDidEnterBackground:.
- */
- }
- #pragma mark -
- #pragma mark - Getting Device token for Notification support
- //向服务器申请发送token 判断事前有没有发送过
- - (void)registerForRemoteNotificationToGetToken
- {
- NSLog(@"Registering for push notifications...");
- //注册Device Token, 需要注册remote notification
- NSUserDefaults *userDefaults = [NSUserDefaults standardUserDefaults];
- if (![userDefaults boolForKey:DeviceTokenRegisteredKEY]) //如果没有注册到令牌 则重新发送注册请求
- {
- dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_HIGH, 0), ^{
- [[UIApplication sharedApplication] registerForRemoteNotificationTypes:
- (UIRemoteNotificationTypeNewsstandContentAvailability |
- UIRemoteNotificationTypeAlert | UIRemoteNotificationTypeBadge |
- UIRemoteNotificationTypeSound)];
- });
- }
- //将远程通知的数量置零
- dispatch_async(dispatch_get_global_queue(0,0), ^{
- //1 hide the local badge
- if ([[UIApplication sharedApplication] applicationIconBadgeNumber] == 0) {
- return;
- }
- // [[UIApplication sharedApplication] setApplicationIconBadgeNumber:0];
- //2 ask the provider to set the BadgeNumber to zero
- NSUserDefaults *userDefaults = [NSUserDefaults standardUserDefaults];
- NSString *deviceTokenStr = [userDefaults objectForKey:DeviceTokenStringKEY];
- [self resetBadgeNumberOnProviderWithDeviceToken:deviceTokenStr];
- });
- }
- //允许的话 自动回调的函数
- - (void)application:(UIApplication *)application didRegisterForRemoteNotificationsWithDeviceToken:(NSData *)deviceToken
- {
- //将device token转换为字符串
- NSString *deviceTokenStr = [NSString stringWithFormat:@"%@",deviceToken];
- //modify the token, remove the "<, >"
- NSLog(@" deviceTokenStr lentgh: %d ->%@", [deviceTokenStr length], [[deviceTokenStr substringWithRange:NSMakeRange(0, 72)] substringWithRange:NSMakeRange(1, 71)]);
- deviceTokenStr = [[deviceTokenStr substringWithRange:NSMakeRange(0, 72)] substringWithRange:NSMakeRange(1, 71)];
- NSLog(@"deviceTokenStr = %@",deviceTokenStr);
- //将deviceToken保存在NSUserDefaults
- NSUserDefaults *userDefaults = [NSUserDefaults standardUserDefaults];
- //保存 device token 令牌,并且去掉空格
- [userDefaults setObject:[deviceTokenStr stringByReplacingOccurrencesOfString:@" " withString:@""] forKey:DeviceTokenStringKEY];
- //send deviceToken to the service provider
- dispatch_async(dispatch_get_global_queue(0,0), ^{
- //没有在service provider注册Device Token, 需要发送令牌到服务器
- if ( ![userDefaults boolForKey:DeviceTokenRegisteredKEY] )
- {
- NSLog(@" 没有 注册Device Token");
- [self sendProviderDeviceToken:deviceTokenStr];
- }
- });
- }
- - (void)application:(UIApplication *)app didFailToRegisterForRemoteNotificationsWithError:(NSError *)err {
- NSString *str = [NSString stringWithFormat: @"Error: %@", err];
- NSLog(@"获取令牌失败: %@",str);
- //如果device token获取失败则需要重新获取一次
- //[NSTimer scheduledTimerWithTimeInterval:0.5 target:self selector:@selector(registerForRemoteNotificationToGetToken) userInfo:nil repeats:NO];
- }
- //获取远程通知
- - (void)application:(UIApplication *)application didReceiveRemoteNotification:(NSDictionary *)userInfo {
- NSLog(@"received badge number ---%@ ----",[[userInfo objectForKey:@"aps"] objectForKey:@"badge"]);
- for (id key in userInfo) {
- NSLog(@"key: %@, value: %@", key, [userInfo objectForKey:key]);
- }
- NSLog(@"the badge number is %d", [[UIApplication sharedApplication] applicationIconBadgeNumber]);
- NSLog(@"the application badge number is %d", application.applicationIconBadgeNumber);
- application.applicationIconBadgeNumber += 1;
- // We can determine whether an application is launched as a result of the user tapping the action
- // button or whether the notification was delivered to the already-running application by examining
- // the application state.
- //当用户打开程序时候收到远程通知后执行
- if (application.applicationState == UIApplicationStateActive) {
- // Nothing to do if applicationState is Inactive, the iOS already displayed an alert view.
- UIAlertView *alertView = [[UIAlertView alloc] initWithTitle:@"温馨提示"
- message:[NSString stringWithFormat:@"\n%@",
- [[userInfo objectForKey:@"aps"] objectForKey:@"alert"]]
- delegate:self
- cancelButtonTitle:@"OK"
- otherButtonTitles:nil];
- dispatch_async(dispatch_get_global_queue(0,0), ^{
- //hide the badge
- application.applicationIconBadgeNumber = 0;
- //ask the provider to set the BadgeNumber to zero
- NSUserDefaults *userDefaults = [NSUserDefaults standardUserDefaults];
- NSString *deviceTokenStr = [userDefaults objectForKey:DeviceTokenStringKEY];
- [self resetBadgeNumberOnProviderWithDeviceToken:deviceTokenStr];
- });
- [alertView show];
- [alertView release];
- }
- }
- // http://192.168.11.24/ClientInterface.ashx?action= savetoken&clientid=3898329492492424924932&token=343424324242
- #pragma mark -
- #pragma mark - Getting Device token for Notification support
- //发送token
- - (void)sendProviderDeviceToken: (NSString *)deviceTokenString
- {
- // Establish the request
- NSLog(@"sendProviderDeviceToken = %@", deviceTokenString);
- NSString *UDIDString = [[UIDevice currentDevice] uniqueIdentifier];
- NSString *body = [NSString stringWithFormat:@"action=savetoken&clientid=%@&token=%@", UDIDString, deviceTokenString];
- NSString *baseurl = [NSString stringWithFormat:@"%@?",URL_OF_PUSH_NOTIFICATION_SERVER]; //服务器地址
- NSLog(@"send provider device token = %@", baseurl);
- NSURL *url = [NSURL URLWithString:baseurl];
- NSMutableURLRequest *urlRequest = [NSMutableURLRequest requestWithURL:url];
- [urlRequest setHTTPMethod: @"POST"];
- [urlRequest setHTTPBody:[body dataUsingEncoding:NSUTF8StringEncoding]];
- [urlRequest setValue:@"application/x-www-form-urlencoded" forHTTPHeaderField:@"Content-Type"];
- NSURLConnection *tConnection = [[NSURLConnection alloc] initWithRequest: urlRequest delegate: self];
- self.deviceTokenConnetion = [tConnection retain];
- [tConnection release];
- }
- #pragma mark -
- #pragma mark - reset Badge Number
- - (void)resetBadgeNumberOnProviderWithDeviceToken: (NSString *)deviceTokenString
- {
- NSLog(@" reset Provider DeviceToken %@", deviceTokenString);
- isNotificationSetBadge = YES;
- // Establish the request
- NSString *body = [NSString stringWithFormat:@"action=setbadge&token=%@", [deviceTokenString stringByReplacingOccurrencesOfString:@" " withString:@""]];
- NSString *baseurl = [NSString stringWithFormat:@"%@?", URL_OF_PUSH_NOTIFICATION_SERVER]; //服务器地址
- NSURL *url = [NSURL URLWithString:baseurl];
- NSMutableURLRequest *urlRequest = [NSMutableURLRequest requestWithURL:url];
- [urlRequest setHTTPMethod: @"POST"];
- [urlRequest setHTTPBody:[body dataUsingEncoding:NSUTF8StringEncoding]];
- [urlRequest setValue:@"application/x-www-form-urlencoded" forHTTPHeaderField:@"Content-Type"];
- NSURLConnection *tConnection = [[NSURLConnection alloc] initWithRequest: urlRequest delegate: self];
- self.deviceTokenConnetion = [tConnection retain];
- [tConnection release];
- }
- #pragma mark -
- #pragma mark - NSURLConnection delegate function
- - (void)connection:(NSURLConnection *)connection didReceiveResponse:(NSURLResponse *)response
- {
- NSHTTPURLResponse *resp = (NSHTTPURLResponse *)response;
- NSLog(@"Response statusCode: %d", resp.statusCode);
- }
- - (void)connection:(NSURLConnection *)connection didReceiveData:(NSData *)data
- {
- NSString *rsp = [[NSString alloc] initWithData:data encoding:NSUTF8StringEncoding];
- NSLog(@"connection 2 Received data = %@ ", rsp);
- //if the string from provider is "true", means the devicetoken is stored in the provider server
- //so the app won't send the devicetoken next time.
- if (isNotificationSetBadge == NO) {
- NSUserDefaults *userDefaults = [NSUserDefaults standardUserDefaults];
- if([rsp isEqualToString:@"true"])
- {
- NSLog(@"connection 2.2 Received data = %@ ", rsp);
- [userDefaults setBool:YES forKey:DeviceTokenRegisteredKEY];
- }
- }else{//isNotificationSetBadge == YES;
- NSLog(@"connection 2 reset");
- isNotificationSetBadge = NO;
- }
- [rsp release];
- }
- - (void)connectionDidFinishLoading:(NSURLConnection *)connection
- {
- NSLog(@"connection 3 Did Finish Loading ");
- [self.deviceTokenConnetion cancel];
- }
ios如何实现推送通知的更多相关文章
- iOS上简单推送通知(Push Notification)的实现
iOS上简单推送通知(Push Notification)的实现 根据这篇很好的教程(http://www.raywenderlich.com/3443/apple-push-notification ...
- 转:向IOS设备发送推送通知
背景 SMS 和 MMS 消息是由无线运营商通过设备的电话号码向特定设备提供的.实现 SMS/MMS 的服务器端应用程序的开发人员必须费大量精力才能与现有的封闭电信基础架构进行交互(其中包括获取电话号 ...
- iOS 玩转推送通知
转自:http://www.cocoachina.com/ios/20160316/15665.html 前言 推送通知,想必大家都很熟悉,关于原理之类的,这里就不过多阐述.在这里我们主要介绍下iOS ...
- 【读书笔记】iOS网络-使用推送通知
一,本地通知 本地通知有64位的最大限制.虽然,你依然可以调度通知,不过到到达的通知数被限定为接近64个,并且按照fireDate的顺序排序,系统会忽略掉其余的通知.这意味着如果现在有64个调用的本地 ...
- iOS 远程推送通知
1.什么是推送通知 在某些特殊情况下,应用程序被动收到的以不同种界面形式出现的提醒信息 推送通知的作用:可以让不在前台运行的app通知app发生了改变 iOS中得推送通知种类 远程推送通知(Remot ...
- 推送通知iOS客户端编写实现及推送服务器端编写
http://blog.csdn.net/tonny_guan/article/details/8963262 1.iOS客户端编程 推送通知技术在Mac OS X和iOS系统上都可以运行,我们本章主 ...
- IOS之推送通知(本地推送和远程推送)
推送通知和NSNotification是有区别的: NSNotification:是看不到的 推送通知:是可以看到的 IOS中提供了两种推送通知 本地推送通知:(Local Notification) ...
- iOS推送通知
推送通知 此通知非彼通知. NSNotification是抽象的,看不见的,但是可以监听,属于观察者模式的一种设计模式. 推送通知是可见的,能用肉眼看见的,是真正的和用户打交道的通知. 推送通知分为两 ...
- iOS推送通知的实现步骤
一.关于推送通知 来源:http://blog.csdn.net/enuola/article/details/8627283 推送通知,也被叫做远程通知,是在iOS 3.0以后被引入的功能.是当程序 ...
随机推荐
- ThreadPool.QueueUserWorkItem的性能问题
在WEB开发中,为了降低页面等待时间提高用户体验,我们往往会把一些浪费时间的操作放到新线程中在后台执行. 简单的实现代码就是: //代码一 new Thread(()=>{ //do somet ...
- js高程笔记--创建对象
1.工厂模式 ex: function createPerson( name, age, job) { var o = new Object() ; o.name = name; o.job = jo ...
- 【译】html5游戏入门
[译]html5游戏入门 原文链接 简介 如果你想用canvas做个游戏,那么来对地方了. 但是但是你至少知道javascript怎么拼写(╯‵□′)╯︵┻━┻ 既然没问题,那先来玩一下或者下载 创建 ...
- JavaScript知识(二)
你要保守你心,胜过保守一切,因为一生的果效,是由心发出的.————O(∩_∩)O... ...O(∩_∩)O...老师因有事下午没来上课,今天就只把中午讲的知识总结一下.由于昨天只是讲了JavaScr ...
- 转 --maven系列之一 简介
http://blog.csdn.net/jiuqiyuliang/article/details/41076215 [项目管理和构建]——Maven简介(一) 2015-01-31 21:27 68 ...
- Linux学习之Makefile文件的编写
转自:http://goodcandle.cnblogs.com/archive/2006/03/30/278702.html 目的: 基本掌握了 make 的用法,能在Linux系统上编 ...
- 《JavaScript+DOM编程艺术》的摘要(四)appendChild与insertBefore的区别
基本知识点: // 1.js里面为什么要添加window.onload=function (){} // 保证html文档都加载完了,才开始运行js代码,以防html文档没有加载完,找不到相应的元素 ...
- PhpStorm 10.0 激活方式
随着 JetBrains 新版本的发布,注册机已然不行了.然而,道高一尺,魔高一丈.IntelliJ IDEA开源社区 提供了如下通用激活方法:注册时选择License server填写http:// ...
- Oracle字符集转换
这几天在工作中碰到一个字符乱码的问题,发现在cmd窗口的sqlplus中直接update一个中文和使用@调用一个文件作同样更新的时候,存储的结果 竟不一样.一时比较迷惑,对Oracle ...
- stl 迭代子的失效
迭代子是STL中很重要的特性,但是其很脆弱(我个人认为),因为使用它的条件很苛刻,一不小心就失效了.其在两中情况下可能会失效. 1.当容器有插入操作时 在初始化了迭代子后,如果容器有插入操作时,迭代子 ...