你好,歡迎來到IOS教程網

 Ios教程網 >> IOS編程開發 >> IOS開發綜合 >> 解析iOS10中的極光推送消息的適配

解析iOS10中的極光推送消息的適配

編輯:IOS開發綜合

iOS10發布後,發現項目中的極光推送接收消息異常了。

查了相關資料後才發現,iOS10中對於通知做了不少改變。同時也發現極光也很快更新了對應的SDK。

現在就把適配修改的做法分享一下,希望對有需要的童鞋有所幫助。

具體做法如下:

注意:必須先安裝Xcode8.0版本。

一、添加相關的SKD,或framework文件

1、添加UserNotification.framework

2、更新jpush的SDK(最新版本:jpush-ios-2.1.9.a)https://www.jiguang.cn

二、進行路徑和消息推送的配置

1、設置jpush的SDK的路徑

2、開啟消息推送功能

三、代碼修改

1、添加userNotification的頭文件

2、添加userNotification的啟用代碼

3、添加jpush的適配代碼

4、添加jpush的代理和代理方法(注意:在appDelegate.m文件中使用)


補充:完整的使用極光

1、導入相應頭文件

#import "JPUSHService.h" 
#import <AdSupport/AdSupport.h> 
#ifdef NSFoundationVersionNumber_iOS_9_x_Max 
// 這裡是iOS10需要用到的框架 
#import <UserNotifications/UserNotifications.h> 
#endif

2、啟動極光推送功能

static NSString *JPushAppKey = @"6abc87b33b23d35b9c3b86e0"; 
static NSString *JPushChannel = @"Publish channel"; 
// static BOOL JPushIsProduction = NO; 
#ifdef DEBUG 
// 開發 極光FALSE為開發環境 
static BOOL const JPushIsProduction = FALSE; 
#else 
// 生產 極光TRUE為生產環境 
static BOOL const JPushIsProduction = TRUE; 
#endif 
[objc] view plain copy 在CODE上查看代碼片派生到我的代碼片
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions { 
// Override point for customization after application launch. 
// 啟動極光推送 
// Required 
// - (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions { } 
if ([[UIDevice currentDevice].systemVersion floatValue] >= 10.0) // iOS10 
{ 
#ifdef NSFoundationVersionNumber_iOS_9_x_Max 
JPUSHRegisterEntity *entity = [[JPUSHRegisterEntity alloc] init]; 
entity.types = (UNAuthorizationOptionAlert | UNAuthorizationOptionBadge | UNAuthorizationOptionSound); 
[JPUSHService registerForRemoteNotificationConfig:entity delegate:target]; 
#endif 
} 
else if ([[UIDevice currentDevice].systemVersion floatValue] >= 8.0) 
{ 
// categories 
[JPUSHService registerForRemoteNotificationTypes:(UIUserNotificationTypeBadge | UIUserNotificationTypeSound | UIUserNotificationTypeAlert) 
categories:nil]; 
} 
else 
{ 
// categories nil 
[JPUSHService registerForRemoteNotificationTypes:(UIRemoteNotificationTypeBadge | UIRemoteNotificationTypeSound | UIRemoteNotificationTypeAlert) 
categories:nil]; 
} 
// Required 
// [JPUSHService setupWithOption:launchOptions] 
// pushConfig.plist appKey 
// 有廣告符標識IDFA(盡量不用,避免上架審核被拒) 
/* 
NSString *JPushAdvertisingId = [[[ASIdentifierManager sharedManager] advertisingIdentifier] UUIDString]; 
[JPUSHService setupWithOption:JPushOptions 
appKey:JPushAppKey 
channel:JPushChannel 
apsForProduction:JPushIsProduction 
advertisingIdentifier:JPushAdvertisingId]; 
*/ 
// 或無廣告符標識IDFA(盡量不用,避免上架審核被拒) 
[JPUSHService setupWithOption:options 
appKey:JPushAppKey 
channel:JPushChannel 
apsForProduction:JPushIsProduction]; 
// 2.1.9版本新增獲取registration id block接口。 
[JPUSHService registrationIDCompletionHandler:^(int resCode, NSString *registrationID) { 
if(resCode == 0) 
{ 
// iOS10獲取registrationID放到這裡了, 可以存到緩存裡, 用來標識用戶單獨發送推送 
NSLog(@"registrationID獲取成功:%@",registrationID); 
[[NSUserDefaults standardUserDefaults] setObject:registrationID forKey:@"registrationID"]; 
[[NSUserDefaults standardUserDefaults] synchronize]; 
} 
else 
{ 
NSLog(@"registrationID獲取失敗,code:%d",resCode); 
} 
}]; 
return YES; 
}

3、注冊

- (void)application:(UIApplication *)application didRegisterForRemoteNotificationsWithDeviceToken:(NSData *)deviceToken 
{ 
[JPUSHService registerDeviceToken:data]; 
}

4、注冊失敗

- (void)application:(UIApplication *)application didFailToRegisterForRemoteNotificwationsWithError:(NSError *)error 
{ 
NSLog(@"did Fail To Register For Remote Notifications With Error: %@", error); 
}

5、接收

- (void)application:(UIApplication *)application didReceiveRemoteNotification:(NSDictionary *)userInfo 
{ 
// apn 內容獲取: 
// 取得 APNs 標准信息內容 
[JPUSHService handleRemoteNotification:dict]; 
}

6、處理通知

6-1、iOS10以下版本時

- (void)application:(UIApplication *)application didReceiveRemoteNotification:(NSDictionary *)userInfo fetchCompletionHandler:(void (^)(UIBackgroundFetchResult))completionHandler 
{ 
DLog(@"2-1 didReceiveRemoteNotification remoteNotification = %@", userInfo); 
// apn 內容獲取: 
[JPUSHService handleRemoteNotification:dict]; 
completionHandler(UIBackgroundFetchResultNewData); 
DLog(@"2-2 didReceiveRemoteNotification remoteNotification = %@", userInfo); 
if ([userInfo isKindOfClass:[NSDictionary class]]) 
{ 
NSDictionary *dict = userInfo[@"aps"]; 
NSString *content = dict[@"alert"]; 
DLog(@"content = %@", content); 
} 
if (application.applicationState == UIApplicationStateActive) 
{ 
// 程序當前正處於前台 
} 
else if (application.applicationState == UIApplicationStateInactive) 
{ 
// 程序處於後台 
} 
}

6-2、iOS10及以上版本時

#pragma mark - iOS10: 收到推送消息調用(iOS10是通過Delegate實現的回調) 
#pragma mark- JPUSHRegisterDelegate 
#ifdef NSFoundationVersionNumber_iOS_9_x_Max 
// 當程序在前台時, 收到推送彈出的通知 
- (void)jpushNotificationCenter:(UNUserNotificationCenter *)center willPresentNotification:(UNNotification *)notification withCompletionHandler:(void (^)(NSInteger))completionHandler 
{ 
NSDictionary *userInfo = notification.request.content.userInfo; 
if ([notification.request.trigger isKindOfClass:[UNPushNotificationTrigger class]]) 
{ 
[JPUSHService handleRemoteNotification:userInfo]; 
} 
// 需要執行這個方法,選擇是否提醒用戶,有Badge、Sound、Alert三種類型可以設置 
// completionHandler(UNNotificationPresentationOptionBadge | UNNotificationPresentationOptionSound | UNNotificationPresentationOptionAlert); 
} 
// 程序關閉後, 通過點擊推送彈出的通知 
- (void)jpushNotificationCenter:(UNUserNotificationCenter *)center didReceiveNotificationResponse:(UNNotificationResponse *)response withCompletionHandler:(void (^)())completionHandler 
{ 
NSDictionary *userInfo = response.notification.request.content.userInfo; 
if ([response.notification.request.trigger isKindOfClass:[UNPushNotificationTrigger class]]) 
{ 
[JPUSHService handleRemoteNotification:userInfo]; 
} 
completionHandler(); // 系統要求執行這個方法 
} 
#endif

7、其他注意事項

為了保證用戶能正常接收,或有針對性的接收通知,登錄成功後(或退出後)需要設置別名、標記。通常都是該邏輯都是寫在用戶登錄APP成功之後,或者是用戶退出當前登錄狀態後。

/// 綁定別名(注意:1 登錄成功或者自動登錄後;2 去除綁定-退出登錄後) 
+ (void)JPushTagsAndAliasInbackgroundTags:(NSSet *)set alias:(NSString *)name 
{ 
// 標簽分組(表示沒有值) 
NSSet *tags = set; 
// 用戶別名(自定義值,nil是表示沒有值) 
NSString *alias = name; 
NSLog(@"tags = %@, alias = %@(registrationID = %@)", tags, alias, [self registrationID]); 
// tags、alias均無值時表示去除綁定 
[JPUSHService setTags:tags aliasInbackground:alias]; 
}

以上所述是小編給大家介紹的解析iOS10中的極光推送消息的適配,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對本站網站的支持!

  1. 上一頁:
  2. 下一頁:
蘋果刷機越獄教程| IOS教程問題解答| IOS技巧綜合| IOS7技巧| IOS8教程
Copyright © Ios教程網 All Rights Reserved