收到推送的準備:前端
首先至於說消息推送的原理,證書配置等等這些我在這裏就不在累述,有不少寫的很好的文章相信您已經能夠搞定這塊,這裏我重點講下各類狀況下的跳轉處理。
複製代碼
####點擊推送觸發的幾個方法:ios
ios7.0以前 - (void)application:(UIApplication *)application didReceiveRemoteNotification:(NSDictionary *)userInfo{ // App 收到推送的通知json
NSLog(@"********** ios7.0以前 **********");
if (application.applicationState == UIApplicationStateActive || application.applicationState == UIApplicationStateBackground) {
}
else
{
}
}
複製代碼
ios 8 - 10 點擊本地推送 觸發的方法後端
/**
ios 10 以前 點擊本地推送 觸發的方法
@param application
@param notification
*/
-(void)application:(UIApplication *)application didReceiveLocalNotification:(UILocalNotification *)notification{
DLog(@"本地通知 %ld",(long)application.applicationState );
// 用戶在前臺
if (application.applicationState == UIApplicationStateInactive ) {
NSDictionary *dic = notification.userInfo;
[self remoteNotificationWith:[dic objectForKey:@"payload"] ];
}
else
{
}
}
複製代碼
*iOS 8 - 10 點擊遠程消息推送 *app
/**
iOS 8 - 10
@param application
@param userInfo
@param completionHandler
*/
- (void)application:(UIApplication *)application didReceiveRemoteNotification:(NSDictionary *)userInfo fetchCompletionHandler:(void (^)(UIBackgroundFetchResult))completionHandler
{
completionHandler(UIBackgroundFetchResultNewData);
// 打印到日誌 textView 中
NSLog(@"********** iOS7.0以後 background **********");
[GeTuiSdk handleRemoteNotification:userInfo];
// 應用在前臺。
if (application.applicationState == UIApplicationStateActive) {
{
}
}
//後臺狀態下,直接跳轉到跳轉頁面。
if (application.applicationState == UIApplicationStateInactive || UIApplicationStateBackground)
{
//後端推送
if ([userInfo[@"payload"] isKindOfClass:[NSString class]] ) {
NSData *jsonData = [userInfo[@"payload"] dataUsingEncoding:NSUTF8StringEncoding];
[self remoteNotificationWith:[NSDictionary dictionaryWithJsonData:jsonData ]];
}
}
}
複製代碼
*iOS10 以後點擊推送的方法 包括本地推送 *測試
/**
ios 10 點擊消息推送的方法 包括點擊本地推送
前端 點擊推送 後端 點擊推送
@param center 、
@param response 、
@param completionHandler 、
*/
- (void)userNotificationCenter:(UNUserNotificationCenter *)center didReceiveNotificationResponse:(UNNotificationResponse *)response withCompletionHandler:(void(^)())completionHandler{
NSLog(@"********** iOS10.0以後 **********");
[[UIApplication sharedApplication] setApplicationIconBadgeNumber:0];
[GeTuiSdk resetBadge];
NSDictionary * userInfo = response.notification.request.content.userInfo;
DLog(@"%@ %@",userInfo , [userInfo[@"payload"] class]);
if ([UIApplication sharedApplication].applicationState == UIApplicationStateActive) {
}
//後臺狀態下,直接跳轉到跳轉頁面。
if ([UIApplication sharedApplication].applicationState == UIApplicationStateInactive || UIApplicationStateBackground)
{
}
completionHandler(UNNotificationPresentationOptionAlert); // 系統要求執行這個 方法
}
複製代碼
這個要根據大家的需求去作,咱們的需求是app在前臺收到消息時候,要 轉成本地推送,而後點擊本地推送的消息能夠作相應的跳轉。fetch
我用的是個推的,在收到個推的透傳消息時候會走這個代理方法,判斷若是在前臺的時候就轉成本地推送 ui
這個是轉成本地推送的方法,固然對於裏面數據的轉換你要根據大家的業務需求和後臺的返回狀況作轉化,由於你在以後點擊本地推送的時候仍是要根據你轉本地推送所傳的值進行對應的跳轉的 - (void)requestLocationNotification:(NSDictionary *)payData{spa
if (IOS_VERSION >= 10) {
//進行用戶權限的申請
//通知內容類
UNMutableNotificationContent * content = [UNMutableNotificationContent new];
//設置通知請求發送時 app圖標上顯示的數字
content.badge = @2;
//設置通知的內容
content.body = payData[@"content"];
//默認的通知提示音
content.sound = [UNNotificationSound defaultSound];
//設置通知的副標題
// content.subtitle = @"這裏是副標題";
//設置通知的標題
content.title = payData[@"title"];
//設置從通知激活app時的launchImage圖片
content.launchImageName = @"icon.png";
content.userInfo = @{@"payload":payData};
//設置5S以後執行
UNTimeIntervalNotificationTrigger * trigger = [UNTimeIntervalNotificationTrigger triggerWithTimeInterval:1 repeats:NO];
UNNotificationRequest * request = [UNNotificationRequest requestWithIdentifier:@"NotificationDefault" content:content trigger:trigger];
//添加通知請求
[[ UNUserNotificationCenter currentNotificationCenter] addNotificationRequest:request withCompletionHandler:^(NSError * _Nullable error) {
}];
}else{
NSDictionary * userInfo = payData;
UILocalNotification *notification=[[UILocalNotification alloc] init];
if (notification!=nil) {
UILocalNotification *notification = [[UILocalNotification alloc] init];
//設置1秒以後
NSDate *pushDate = [NSDate dateWithTimeIntervalSinceNow:1];
if (notification != nil) {
notification.fireDate = pushDate;
notification.timeZone = [NSTimeZone defaultTimeZone];
notification.repeatInterval = 0;
notification.soundName = UILocalNotificationDefaultSoundName;
if (userInfo[@"title"]) {
notification.alertTitle = userInfo[@"title"];
}
if (userInfo[@"content"]) {
notification.alertBody = userInfo[@"content"];
}else{
notification.alertBody = @"您有新的消息";
} if (userInfo ) {
NSMutableDictionary *info = [NSMutableDictionary dictionaryWithObject:userInfo forKey:@"payload"];
notification.userInfo = info;
}
DLog(@"%@ %@",userInfo , notification);
UIApplication *app = [UIApplication sharedApplication];
[app scheduleLocalNotification:notification];
}
}
}
}
複製代碼
app 在前臺的時候當接收到消息推送的時候,若是你不作任何處理默認是不會有提示的,通常的處理方式就是透傳的消息轉化成本地消息推送,而後當用戶點擊的時候作相應的跳轉,固然也有能夠直接作彈窗提醒,而後作對應的處理。代理
點擊本地推送觸發的方法
iOS 10以前
-(void)application:(UIApplication *)application didReceiveLocalNotification:(UILocalNotification *)notification
複製代碼
iOS 10 以後
- (void)userNotificationCenter:(UNUserNotificationCenter *)center didReceiveNotificationResponse:(UNNotificationResponse *)response withCompletionHandler:(void(^)())completionHandler
複製代碼
app 在不是殺死狀態 這個時候點擊通知 會走以下方法
iOS 7以前 - (void)application:(UIApplication *)application didReceiveRemoteNotification:(NSDictionary *)userInfo
iOS 8 - 10
- (void)application:(UIApplication *)application didReceiveRemoteNotification:(NSDictionary *)userInfo fetchCompletionHandler:(void (^)(UIBackgroundFetchResult))completionHandler ios 10以後 - (void)userNotificationCenter:(UNUserNotificationCenter *)center didReceiveNotificationResponse:(UNNotificationResponse *)response withCompletionHandler:(void(^)())completionHandler
這個時候你會發現 前臺後臺的時候走的多是一個方法,在這裏咱們就要在方法中作下區分
這個時候會走didReceiveRemoteNotification這些的方法(有不少人認爲不會走,通過測試這個是會走的),可是這這裏面寫跳轉什麼的 ,就有點比較難處理了,由於didFinishLaunchingWithOptions這個方法沒有走,先走的didReceiveRemoteNotification再走的 didFinishLaunchingWithOptions 。這時候不少app的基本設置,好比作的跟視圖,自動登錄,等等不少的註冊什麼的都還沒執行,就直接跳轉這個是很麻煩的處理起來,因此在這裏直接在下面的方法中作處理
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
複製代碼
至此,這幾種狀況就處理完了,總結下就是 app 在前臺,後臺,殺死,點擊推送爲本地,遠端。 作不一樣的處理。 1.前臺在收到消息的時候作相應的處理好比轉本地推送,彈窗提醒等 2.後臺是在點擊消息的時候作處理(由於後臺的時候推送消息過來以後,的展現蘋果已經幫我作好了,直接處理點擊挑戰就好了,固然若是是本地推送那是咱們本身作處理的) 3.殺死的時候點擊消息啓動在 didFinishLaunchingWithOptions 作相應的跳轉處理。
但願這篇文章可以幫到你,總結的有點亂,有疑問的地方歡迎留言。