日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

iOS 点击推送消息跳转指定界面 —总结篇

發(fā)布時(shí)間:2025/3/8 编程问答 26 豆豆
生活随笔 收集整理的這篇文章主要介紹了 iOS 点击推送消息跳转指定界面 —总结篇 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

收到推送的準(zhǔn)備:

首先至于說消息推送的原理,證書配置等等這些我在這里就不在累述,有很多寫的很好的文章相信您已經(jīng)可以搞定這塊,這里我重點(diǎn)講下各種情況下的跳轉(zhuǎn)處理。 復(fù)制代碼

####點(diǎn)擊推送觸發(fā)的幾個(gè)方法:

ios7.0之前 - (void)application:(UIApplication *)application didReceiveRemoteNotification:(NSDictionary *)userInfo{ // App 收到推送的通知

NSLog(@"********** ios7.0之前 **********");if (application.applicationState == UIApplicationStateActive || application.applicationState == UIApplicationStateBackground) {} else{}} 復(fù)制代碼

ios 8 - 10 點(diǎn)擊本地推送 觸發(fā)的方法

/**ios 10 之前 點(diǎn)擊本地推送 觸發(fā)的方法@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{}} 復(fù)制代碼

*iOS 8 - 10 點(diǎn)擊遠(yuǎn)程消息推送 *

/**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]; // 應(yīng)用在前臺。 if (application.applicationState == UIApplicationStateActive) {{} } //后臺狀態(tài)下,直接跳轉(zhuǎn)到跳轉(zhuǎn)頁面。 if (application.applicationState == UIApplicationStateInactive || UIApplicationStateBackground) {//后端推送if ([userInfo[@"payload"] isKindOfClass:[NSString class]] ) {NSData *jsonData = [userInfo[@"payload"] dataUsingEncoding:NSUTF8StringEncoding];[self remoteNotificationWith:[NSDictionary dictionaryWithJsonData:jsonData ]];}}} 復(fù)制代碼

*iOS10 之后點(diǎn)擊推送的方法 包括本地推送 *

/**ios 10 點(diǎn)擊消息推送的方法 包括點(diǎn)擊本地推送前端 點(diǎn)擊推送 后端 點(diǎn)擊推送@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) {} //后臺狀態(tài)下,直接跳轉(zhuǎn)到跳轉(zhuǎn)頁面。if ([UIApplication sharedApplication].applicationState == UIApplicationStateInactive || UIApplicationStateBackground){}completionHandler(UNNotificationPresentationOptionAlert); // 系統(tǒng)要求執(zhí)行這個(gè) 方法 } 復(fù)制代碼

做消息跳轉(zhuǎn)無外乎是在這幾個(gè)方法中,但是上面陳述的這些方法都只是針對系統(tǒng)版本做的分類,對于跳轉(zhuǎn)我們還要考慮下其他情況,點(diǎn)擊消息跳轉(zhuǎn)到指定的界面,這個(gè)時(shí)候要分3種情況 app 在前臺(轉(zhuǎn)本地推送)

這個(gè)要根據(jù)你們的需求去做,我們的需求是app在前臺收到消息時(shí)候,要 轉(zhuǎn)成本地推送,然后點(diǎn)擊本地推送的消息可以做相應(yīng)的跳轉(zhuǎn)。

我用的是個(gè)推的,在收到個(gè)推的透傳消息時(shí)候會走這個(gè)代理方法,判斷如果在前臺的時(shí)候就轉(zhuǎn)成本地推送

這個(gè)是轉(zhuǎn)成本地推送的方法,當(dāng)然對于里面數(shù)據(jù)的轉(zhuǎn)換你要根據(jù)你們的業(yè)務(wù)需求和后臺的返回情況做轉(zhuǎn)化,因?yàn)槟阍谥簏c(diǎn)擊本地推送的時(shí)候還是要根據(jù)你轉(zhuǎn)本地推送所傳的值進(jìn)行對應(yīng)的跳轉(zhuǎn)的 - (void)requestLocationNotification:(NSDictionary *)payData{

if (IOS_VERSION >= 10) {//進(jìn)行用戶權(quán)限的申請//通知內(nèi)容類UNMutableNotificationContent * content = [UNMutableNotificationContent new];//設(shè)置通知請求發(fā)送時(shí) app圖標(biāo)上顯示的數(shù)字content.badge = @2;//設(shè)置通知的內(nèi)容content.body = payData[@"content"];//默認(rèn)的通知提示音content.sound = [UNNotificationSound defaultSound];//設(shè)置通知的副標(biāo)題// content.subtitle = @"這里是副標(biāo)題";//設(shè)置通知的標(biāo)題content.title = payData[@"title"];//設(shè)置從通知激活app時(shí)的launchImage圖片content.launchImageName = @"icon.png";content.userInfo = @{@"payload":payData};//設(shè)置5S之后執(zhí)行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];//設(shè)置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];}}}} 復(fù)制代碼

app 在前臺的時(shí)候當(dāng)接收到消息推送的時(shí)候,如果你不做任何處理默認(rèn)是不會有提示的,一般的處理方式就是透傳的消息轉(zhuǎn)化成本地消息推送,然后當(dāng)用戶點(diǎn)擊的時(shí)候做相應(yīng)的跳轉(zhuǎn),當(dāng)然也有可以直接做彈窗提醒,然后做對應(yīng)的處理。

點(diǎn)擊本地推送觸發(fā)的方法

iOS 10之前

-(void)application:(UIApplication *)application didReceiveLocalNotification:(UILocalNotification *)notification 復(fù)制代碼

iOS 10 之后

- (void)userNotificationCenter:(UNUserNotificationCenter *)center didReceiveNotificationResponse:(UNNotificationResponse *)response withCompletionHandler:(void(^)())completionHandler 復(fù)制代碼

app 在后臺

app 在不是殺死狀態(tài) 這個(gè)時(shí)候點(diǎn)擊通知 會走如下方法

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

這個(gè)時(shí)候你會發(fā)現(xiàn) 前臺后臺的時(shí)候走的可能是一個(gè)方法,在這里我們就要在方法中做下區(qū)分

app被殺死

這個(gè)時(shí)候會走didReceiveRemoteNotification這些的方法(有很多人認(rèn)為不會走,經(jīng)過測試這個(gè)是會走的),但是這這里面寫跳轉(zhuǎn)什么的 ,就有點(diǎn)比較難處理了,因?yàn)閐idFinishLaunchingWithOptions這個(gè)方法沒有走,先走的didReceiveRemoteNotification再走的 didFinishLaunchingWithOptions 。這時(shí)候很多app的基本設(shè)置,比如做的跟視圖,自動(dòng)登陸,等等很多的注冊什么的都還沒執(zhí)行,就直接跳轉(zhuǎn)這個(gè)是很麻煩的處理起來,所以在這里直接在下面的方法中做處理

- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions 復(fù)制代碼

至此,這幾種情況就處理完了,總結(jié)下就是 app 在前臺,后臺,殺死,點(diǎn)擊推送為本地,遠(yuǎn)端。 做不同的處理。 1.前臺在收到消息的時(shí)候做相應(yīng)的處理比如轉(zhuǎn)本地推送,彈窗提醒等 2.后臺是在點(diǎn)擊消息的時(shí)候做處理(因?yàn)楹笈_的時(shí)候推送消息過來之后,的展示蘋果已經(jīng)幫我做好了,直接處理點(diǎn)擊挑戰(zhàn)就行了,當(dāng)然如果是本地推送那是我們自己做處理的) 3.殺死的時(shí)候點(diǎn)擊消息啟動(dòng)在 didFinishLaunchingWithOptions 做相應(yīng)的跳轉(zhuǎn)處理。

希望這篇文章能夠幫到你,總結(jié)的有點(diǎn)亂,有疑問的地方歡迎留言。

轉(zhuǎn)載于:https://juejin.im/post/5b4f0828e51d45195423c585

與50位技術(shù)專家面對面20年技術(shù)見證,附贈技術(shù)全景圖

總結(jié)

以上是生活随笔為你收集整理的iOS 点击推送消息跳转指定界面 —总结篇的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。