iOS个推远程推送和本地通知

许多集成的步骤个推官网都有了,这里只写关于推送的远程推送和本地通知的步骤和代码。APP在后台时:走苹果的APNS通知APP在前台或运行时:做本地通知进行推送AppDelegate.h1.先导入头文件#import "GeTuiSdk.h"2.宏定义#define kGtAppId          @""#define kGtAppKey          @""#define kGtAppSecret      @""3.添加代理@interface AppDelegate : UIResponderAppDelegate.m//个推推送1.宏定义#if __IPHONE_OS_VERSION_MAX_ALLOWED >= __IPHONE_10_0#import#endif2.添加代理@interface AppDelegate ()AppDelegate代理中

- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {

// Override point for customization after application launch.

//注册本地通知

[self registLocationNotification];

//个推-推送功能

// [ GTSdk ]:是否允许APP后台运行

//    [GeTuiSdk runBackgroundEnable:YES];

// [ GTSdk ]:是否运行电子围栏Lbs功能和是否SDK主动请求用户定位

[GeTuiSdk lbsLocationEnable:YES andUserVerify:YES];

// [ GTSdk ]:自定义渠道

[GeTuiSdk setChannelId:@"GT-Channel"];

// [ GTSdk ]:使用APPID/APPKEY/APPSECRENT创建个推实例

[GeTuiSdk startSdkWithAppId:kGtAppId appKey:kGtAppKey appSecret:kGtAppSecret delegate:self];

// 注册APNs - custom method - 开发者自定义的方法

[self registerRemoteNotification];

return YES;

}

本地通知注册

#pragma mark注册本地通知

-(void)registLocationNotification

{

if ([[UIDevice currentDevice].systemVersion floatValue] >= 10.0){

// 使用 UNUserNotificationCenter 来管理通知

UNUserNotificationCenter *center = [UNUserNotificationCenter currentNotificationCenter];

//监听回调事件

center.delegate = self;

//iOS 10 使用以下方法注册,才能得到授权

[center requestAuthorizationWithOptions:(UNAuthorizationOptionAlert + UNAuthorizationOptionSound)

completionHandler:^(BOOL granted, NSError * _Nullable error) {

// Enable or disable features based on authorization.

}];

//获取当前的通知设置,UNNotificationSettings 是只读对象,不能直接修改,只能通过以下方法获取

[center getNotificationSettingsWithCompletionHandler:^(UNNotificationSettings * _Nonnull settings) {

}];

}else if ([[UIDevice currentDevice].systemVersion floatValue] >= 8.0&&[[UIDevice currentDevice].systemVersion floatValue] < 10.0){

if ([[UIApplication sharedApplication] respondsToSelector:@selector(registerUserNotificationSettings:)]) {

UIUserNotificationSettings *settings = [UIUserNotificationSettings settingsForTypes:UIUserNotificationTypeBadge|UIUserNotificationTypeSound|UIUserNotificationTypeAlert categories:nil];

[[UIApplication sharedApplication] registerUserNotificationSettings:settings];

}

}

}

注册个推的远程推送

#pragma mark - 用户通知(推送) _自定义方法

/** 注册远程通知 */

- (void)registerRemoteNotification {

/*

警告:Xcode8的需要手动开启“TARGETS -> Capabilities -> Push Notifications”

*/

/*

警告:该方法需要开发者自定义,以下代码根据APP支持的iOS系统不同,代码可以对应修改。

以下为演示代码,注意根据实际需要修改,注意测试支持的iOS系统都能获取到DeviceToken

*/

if ([[UIDevice currentDevice].systemVersion floatValue] >= 10.0) {

#if __IPHONE_OS_VERSION_MAX_ALLOWED >= __IPHONE_10_0 // Xcode 8编译会调用

UNUserNotificationCenter *center = [UNUserNotificationCenter currentNotificationCenter];

center.delegate = self;

[center requestAuthorizationWithOptions:(UNAuthorizationOptionBadge | UNAuthorizationOptionSound | UNAuthorizationOptionAlert | UNAuthorizationOptionCarPlay) completionHandler:^(BOOL granted, NSError *_Nullable error) {

if (!error) {

NSLog(@"request authorization succeeded!");

}

}];

[[UIApplication sharedApplication] registerForRemoteNotifications];

#else // Xcode 7编译会调用

UIUserNotificationType types = (UIUserNotificationTypeAlert | UIUserNotificationTypeSound | UIUserNotificationTypeBadge);

UIUserNotificationSettings *settings = [UIUserNotificationSettings settingsForTypes:types categories:nil];

[[UIApplication sharedApplication] registerUserNotificationSettings:settings];

[[UIApplication sharedApplication] registerForRemoteNotifications];

#endif

} else if ([[[UIDevice currentDevice] systemVersion] floatValue] >= 8.0) {

UIUserNotificationType types = (UIUserNotificationTypeAlert | UIUserNotificationTypeSound | UIUserNotificationTypeBadge);

UIUserNotificationSettings *settings = [UIUserNotificationSettings settingsForTypes:types categories:nil];

[[UIApplication sharedApplication] registerUserNotificationSettings:settings];

[[UIApplication sharedApplication] registerForRemoteNotifications];

} else {

UIRemoteNotificationType apn_type = (UIRemoteNotificationType)(UIRemoteNotificationTypeAlert |

UIRemoteNotificationTypeSound |

UIRemoteNotificationTypeBadge);

[[UIApplication sharedApplication] registerForRemoteNotificationTypes:apn_type];

}

}

注册APNS成功返回具体的信息

#pragma mark - 远程通知(推送)回调

/** 远程通知注册成功委托 */

- (void)application:(UIApplication *)application didRegisterForRemoteNotificationsWithDeviceToken:(NSData *)deviceToken {

NSString *token = [[deviceToken description] stringByTrimmingCharactersInSet:[NSCharacterSet characterSetWithCharactersInString:@"<>"]];

token = [token stringByReplacingOccurrencesOfString:@" " withString:@""];

NSLog(@"\n>>>[DeviceToken Success]:%@\n\n", token);

// [ GTSdk ]:向个推服务器注册deviceToken

[GeTuiSdk registerDeviceToken:token];

}

/** 远程通知注册失败委托 */

- (void)application:(UIApplication *)application didFailToRegisterForRemoteNotificationsWithError:(NSError *)error {

NSLog(@"\n>>>[DeviceToken Error]:%@\n\n", error.description);

}

收到远程推送,角标加1

#pragma mark - APP运行中接收到通知(推送)处理 - iOS 10以下版本收到推送

/** APP已经接收到“远程”通知(推送) - 透传推送消息  */

- (void)application:(UIApplication *)application didReceiveRemoteNotification:(NSDictionary *)userInfo fetchCompletionHandler:(void (^)(UIBackgroundFetchResult result))completionHandler {

[GeTuiSdk setBadge:[UIApplication sharedApplication].applicationIconBadgeNumber+1];

// [ GTSdk ]:将收到的APNs信息传给个推统计

[GeTuiSdk handleRemoteNotification:userInfo];

// 控制台打印接收APNs信息

NSLog(@"\n>>>[Receive RemoteNotification]:%@\n\n", userInfo);

completionHandler(UIBackgroundFetchResultNewData);

}

#pragma mark - iOS 10中收到推送消息

#if __IPHONE_OS_VERSION_MAX_ALLOWED >= __IPHONE_10_0

//  iOS 10: App在前台获取到通知

- (void)userNotificationCenter:(UNUserNotificationCenter *)center willPresentNotification:(UNNotification *)notification withCompletionHandler:(void (^)(UNNotificationPresentationOptions))completionHandler {

NSLog(@"willPresentNotification:%@", notification.request.content.userInfo);

// 根据APP需要,判断是否要提示用户Badge、Sound、Alert

completionHandler(UNNotificationPresentationOptionBadge | UNNotificationPresentationOptionSound | UNNotificationPresentationOptionAlert);

completionHandler(UNNotificationPresentationOptionAlert);

}

###收到远程推送打开app时做的跳转页面###

//  iOS 10: 点击通知进入App时触发

- (void)userNotificationCenter:(UNUserNotificationCenter *)center didReceiveNotificationResponse:(UNNotificationResponse *)response withCompletionHandler:(void (^)())completionHandler {

NSLog(@"didReceiveNotification:%@", response.notification.request.content.userInfo);

// [ GTSdk ]:将收到的APNs信息传给个推统计

[GeTuiSdk handleRemoteNotification:response.notification.request.content.userInfo];

//跳转页面

DetailContentVC *detailVC=[DetailContentVC new];

detailVC.titleValue=_webTitle;

detailVC.requestUrl=_webUrl;

detailVC.hidesBottomBarWhenPushed=YES;

self.window.rootViewController.hidesBottomBarWhenPushed=NO;

[((UITabBarController *)self.window.rootViewController).selectedViewController pushViewController:detailVC animated:YES];

completionHandler();

}

#endif

注册远程推送返回来的cid

#pragma mark - GeTuiSdkDelegate

/** SDK启动成功返回cid */

- (void)GeTuiSdkDidRegisterClient:(NSString *)clientId {

// [4-EXT-1]: 个推SDK已注册,返回clientId

NSLog(@"\n>>[GTSdk RegisterClient]:%@\n\n", clientId);

}

/** SDK遇到错误回调 */

- (void)GeTuiSdkDidOccurError:(NSError *)error {

// [EXT]:个推错误报告,集成步骤发生的任何错误都在这里通知,如果集成后,无法正常收到消息,查看这里的通知。

NSLog(@"\n>>[GTSdk error]:%@\n\n", [error localizedDescription]);

}

透传消息都会走这个,这边是接收离线消息的方法,在这里面去做判断去做本地通知还是远程推送,如果是本地通知,则去注册消息,否则不做任何动作

/** SDK收到透传消息回调 */

- (void)GeTuiSdkDidReceivePayloadData:(NSData *)payloadData andTaskId:(NSString *)taskId andMsgId:(NSString *)msgId andOffLine:(BOOL)offLine fromGtAppId:(NSString *)appId {

// [ GTSdk ]:汇报个推自定义事件(反馈透传消息)

[GeTuiSdk sendFeedbackMessage:90001 andTaskId:taskId andMsgId:msgId];

// 数据转换

NSString *payloadMsg = nil;

if (payloadData) {

payloadMsg = [[NSString alloc] initWithBytes:payloadData.bytes length:payloadData.length encoding:NSUTF8StringEncoding];

}

// 控制台打印日志

NSString *msg = [NSString stringWithFormat:@"taskId=%@,messageId:%@,payloadMsg:%@%@", taskId, msgId, payloadMsg, offLine ? @"<离线消息>" : @""];

NSLog(@"\n>>[GTSdk ReceivePayload]:%@\n\n", msg);

NSError *error=nil;

NSDictionary *dic=[NSJSONSerialization JSONObjectWithData:payloadData options:NSJSONReadingMutableContainers error:&error];

NSString *title=[NSString stringWithFormat:@"%@",dic[@"title"]];

NSString *detail=[NSString stringWithFormat:@"%@",dic[@"text"]];

_webTitle=[NSString stringWithFormat:@"%@",dic[@"messageTitle"]];

_webUrl=[NSString stringWithFormat:@"%@",dic[@"messageUrl"]];

// 当app不在前台时,接收到的推送消息offLine值均为YES

// 判断app是否是点击通知栏消息进行唤醒或开启

// 如果是点击icon图标使得app进入前台,则不做操作,并且同一条推送通知,此方法只执行一次

if (!offLine) {//  离线消息已经有苹果的apns推过消息了,避免上线后再次受到消息

if ([[UIDevice currentDevice].systemVersion floatValue] >= 10.0){

[self registerNotification:1 andTitle:title andMess:detail];

}else{

[self registerLocalNotificationInOldWay:1 andTitle:title andMess:detail];

}

}

}

在app运行时恢复个推sdk运行

- (void)application:(UIApplication *)application performFetchWithCompletionHandler:(void (^)(UIBackgroundFetchResult))completionHandler {

/// Background Fetch 恢复SDK 运行

[GeTuiSdk resume];

completionHandler(UIBackgroundFetchResultNewData);

}

/** SDK收到sendMessage消息回调 */

- (void)GeTuiSdkDidSendMessage:(NSString *)messageId result:(int)result {

// 发送上行消息结果反馈

NSString *msg = [NSString stringWithFormat:@"sendmessage=%@,result=%d", messageId, result];

NSLog(@"\n>>[GTSdk DidSendMessage]:%@\n\n", msg);

}

/** SDK运行状态通知 */

- (void)GeTuiSDkDidNotifySdkState:(SdkStatus)aStatus {

// 通知SDK运行状态

NSLog(@"\n>>[GTSdk SdkState]:%u\n\n", aStatus);

}

/** SDK设置推送模式回调 */

- (void)GeTuiSdkDidSetPushMode:(BOOL)isModeOff error:(NSError *)error {

if (error) {

NSLog(@"\n>>[GTSdk SetModeOff Error]:%@\n\n", [error localizedDescription]);

return;

}

NSLog(@"\n>>[GTSdk SetModeOff]:%@\n\n", isModeOff ? @"开启" : @"关闭");

}

在通知栏点击进来的时候做角标的变化

- (void)handlePushMessage:(NSDictionary *)dict notification:(UILocalNotification *)localNotification {

//开始处理从通知栏点击进来的推送消息

if ([UIApplication sharedApplication].applicationIconBadgeNumber != 0) {

if (localNotification) {

//删除相应信息栏

[[UIApplication sharedApplication] cancelLocalNotification:localNotification];

}

//应用的数字角标减1

[UIApplication sharedApplication].applicationIconBadgeNumber -= 1;

}

else {

[[UIApplication sharedApplication] cancelAllLocalNotifications];

[UIApplication sharedApplication].applicationIconBadgeNumber = 0;

}

}

注册本地通知消息

#pragma mark本地推送

#if __IPHONE_OS_VERSION_MAX_ALLOWED >= __IPHONE_10_0

//使用 UNNotification 本地通知

-(void)registerNotification:(NSInteger )alerTime andTitle:(NSString*)title andMess:(NSString*)mes{

// 使用 UNUserNotificationCenter 来管理通知

UNUserNotificationCenter* center = [UNUserNotificationCenter currentNotificationCenter];

//需创建一个包含待通知内容的 UNMutableNotificationContent 对象,注意不是 UNNotificationContent ,此对象为不可变对象。

UNMutableNotificationContent* content = [[UNMutableNotificationContent alloc] init];

content.title = [NSString localizedUserNotificationStringForKey:title arguments:nil];

content.body = [NSString localizedUserNotificationStringForKey:mes

arguments:nil];

content.sound = [UNNotificationSound defaultSound];

content.userInfo=@{@"webTitle":_webTitle,@"webUrl":_webUrl};

// 在 alertTime 后推送本地推送

UNTimeIntervalNotificationTrigger* trigger = [UNTimeIntervalNotificationTrigger

triggerWithTimeInterval:alerTime repeats:NO];

UNNotificationRequest* request = [UNNotificationRequest requestWithIdentifier:@"FiveSecond"

content:content trigger:trigger];

//添加推送成功后的处理!

[center addNotificationRequest:request withCompletionHandler:^(NSError * _Nullable error) {

}];

[[UIApplication sharedApplication] setApplicationIconBadgeNumber:[UIApplication sharedApplication].applicationIconBadgeNumber+1];

[GeTuiSdk setBadge:[UIApplication sharedApplication].applicationIconBadgeNumber];

}

#endif

- (void)registerLocalNotificationInOldWay:(NSInteger)alertTime andTitle:(NSString*)title andMess:(NSString*)mes{

UILocalNotification *notification = [[UILocalNotification alloc] init];

// 设置触发通知的时间

NSDate *fireDate = [NSDate dateWithTimeIntervalSinceNow:alertTime];

NSLog(@"fireDate=%@",fireDate);

notification.fireDate = fireDate;

// 时区

notification.timeZone = [NSTimeZone defaultTimeZone];

// 设置重复的间隔-不重复

notification.repeatInterval = kCFCalendarUnitEra;

// 通知内容

notification.alertBody = title;

notification.applicationIconBadgeNumber = 1;

// 通知被触发时播放的声音

notification.soundName = UILocalNotificationDefaultSoundName;

// 通知参数

NSDictionary *userDict = [NSDictionary dictionaryWithObject:mes forKey:@"key"];

notification.userInfo = userDict;

// ios8后,需要添加这个注册,才能得到授权

if ([[UIApplication sharedApplication] respondsToSelector:@selector(registerUserNotificationSettings:)]) {

UIUserNotificationType type = UIUserNotificationTypeAlert | UIUserNotificationTypeBadge | UIUserNotificationTypeSound;

UIUserNotificationSettings *settings = [UIUserNotificationSettings settingsForTypes:type

categories:nil];

[[UIApplication sharedApplication] registerUserNotificationSettings:settings];

// 通知重复提示的单位,可以是天、周、月

notification.repeatInterval = NSCalendarUnitDay;

} else {

// 通知重复提示的单位,可以是天、周、月

notification.repeatInterval = NSDayCalendarUnit;

}

// 执行通知注册

[[UIApplication sharedApplication] scheduleLocalNotification:notification];

[[UIApplication sharedApplication] setApplicationIconBadgeNumber:[UIApplication sharedApplication].applicationIconBadgeNumber+1];

[GeTuiSdk setBadge:[UIApplication sharedApplication].applicationIconBadgeNumber];

}

在进入前台的时候要将所有app角标清空,同时告诉个推此时角标为0

- (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.

[self updateExpriedStatue];

//推送个数大于0

if (application.applicationIconBadgeNumber>0) {  //badge number 不为0,说明程序有那个圈圈图标

//这里进行有关处理

[application setApplicationIconBadgeNumber:0];  //将图标清零。

[GeTuiSdk setBadge:0];

}

}

至此,个推的远程推送和本地通知完成。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 206,214评论 6 481
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,307评论 2 382
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 152,543评论 0 341
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,221评论 1 279
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,224评论 5 371
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,007评论 1 284
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,313评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,956评论 0 259
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,441评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,925评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,018评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,685评论 4 322
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,234评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,240评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,464评论 1 261
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,467评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,762评论 2 345

推荐阅读更多精彩内容

  • 许多集成的步骤个推官网都有了,这里只写关于推送的远程推送和本地通知的步骤和代码。 APP在后台时:走苹果的APNS...
    离离离离阅读 3,678评论 4 8
  • 概述 在多数移动应用中任何时候都只能有一个应用程序处于活跃状态,如果其他应用此刻发生了一些用户感兴趣的那么通过通知...
    莫离_焱阅读 6,490评论 1 8
  • 极光推送: 1.JPush当前版本是1.8.2,其SDK的开发除了正常的功能完善和扩展外也紧随苹果官方的步伐,SD...
    Isspace阅读 6,696评论 10 16
  • 在简单项目中,有使用到apns推送服务,许多文章有涉及到却没有讲清楚。最近做福路通项目,有使用到,做一个总结。 推...
    天空的守望者阅读 897评论 0 3
  • 千秋岁.武汉谢师 汤逊湖畔。江夏桂花灿。教师节,思绪乱。风华正茂时,良师多行善。青春苦,桃李春风...
    金儒圣追求成功的浪子阅读 214评论 0 0