友盟消息推送SDK集成

1.創(chuàng)建應(yīng)用

在友盟有賬號(hào)的情況下(沒有的請(qǐng)自行創(chuàng)建),創(chuàng)建應(yīng)用之前需要去蘋果開發(fā)者網(wǎng)站申請(qǐng)一個(gè)App ID和配置一個(gè)用于推送的APNs證書,下載并安裝APNs推送證書后,打開鑰匙串從這個(gè)證書導(dǎo)出一個(gè).P12的證書文件并保存下來用于創(chuàng)建應(yīng)用。對(duì)APNs證書不了解的可以參考宏創(chuàng)學(xué)院提供的證書設(shè)置指南:

證書配置友盟官網(wǎng)

首先在友盟消息推送功能中創(chuàng)建一個(gè)應(yīng)用,上傳我們的證書:

創(chuàng)建好應(yīng)用后進(jìn)入應(yīng)用詳情頁面,點(diǎn)擊應(yīng)用信息,可以看到我們的AppKey和App Master Secret,證書也可以在這里進(jìn)行修改。

2.下載iOS SDK

友盟iOS SDK文檔

選擇合適版本的SDK,下載下來之后解壓壓縮包,找到UMessage_Sdk_1.2.3(1.2.3為版本號(hào),本文以1.2.3示例) 文件夾,里面就是我們需要的文件了(一個(gè).a的庫文件,一個(gè).h頭文件)。

3.SDK基本功能集成

將上述的UMessage_Sdk_1.2.3文件夾拖入工程,若工程的Other Linker Flag中設(shè)置了-all_load,則需要添加libz.dylib(iOS 9為lib.tbd)庫

在AppDelegate類中引入頭文件Message.h,在AppDelegate.m的application:didFinishLaunchingWithOptions方法中初始化并注冊(cè)友盟推送

//初始化友盟推送

[UMessagestartWithAppkey:@"568cd65be0f55ac5610017ea"launchOptions:launchOptions];

#if __IPHONE_OS_VERSION_MAX_ALLOWED >= __IPHONE_8_0

//iOS 8之后使用此種方法注冊(cè)

if([[[UIDevicecurrentDevice]systemVersion]floatValue]>=8.0){

//遠(yuǎn)程消息注冊(cè)類型

UIMutableUserNotificationAction*action1=[[UIMutableUserNotificationActionalloc]init];

action1.identifier=@"action1_identifier";

action1.title=@"Accept";

action1.activationMode=UIUserNotificationActivationModeForeground;// 當(dāng)點(diǎn)擊的時(shí)候啟動(dòng)程序

// 第二按鈕

UIMutableUserNotificationAction*action2=[[UIMutableUserNotificationActionalloc]init];

action2.identifier=@"action2_identifier";

action2.title=@"Reject";

// 當(dāng)點(diǎn)擊的時(shí)候不啟動(dòng)程序,在后臺(tái)處理

action2.activationMode=UIUserNotificationActivationModeBackground;

// 需要解鎖才能處理,如果action.activationMode = UIUserNotificationActivationModeForeground;則下面這個(gè)屬性被忽略

action2.authenticationRequired=YES;

action2.destructive=YES;

UIMutableUserNotificationCategory*categorys=[[UIMutableUserNotificationCategoryalloc]init];

// 這組動(dòng)作的唯一標(biāo)示

categorys.identifier=@"category1";

[categorys setActions:@[action1,action2]forContext:(UIUserNotificationActionContextDefault)];

UIUserNotificationTypetypes=UIUserNotificationTypeBadge

|UIUserNotificationTypeSound

|UIUserNotificationTypeAlert;

UIUserNotificationSettings*userSettings=[UIUserNotificationSettingssettingsForTypes:types

categories:[NSSetsetWithObject:categorys]];

[UMessageregisterRemoteNotificationAndUserNotificationSettings:userSettings];

}else{

// 遠(yuǎn)程消息注冊(cè)類型

UIRemoteNotificationTypetypes=UIRemoteNotificationTypeBadge

|UIRemoteNotificationTypeSound

|UIRemoteNotificationTypeAlert;

[UMessageregisterForRemoteNotificationTypes:types];

}

#else

// iOS8.0之前使用此注冊(cè)

// 遠(yuǎn)程消息注冊(cè)類型

UIRemoteNotificationTypetypes=UIRemoteNotificationTypeBadge

|UIRemoteNotificationTypeSound

|UIRemoteNotificationTypeAlert;

[UMessageregisterForRemoteNotificationTypes:types];

#endif

//打開調(diào)試日志

[UMessagesetLogEnabled:YES];

//不自動(dòng)清空角標(biāo)

[UMessagesetBadgeClear:NO];

//app發(fā)送渠道,默認(rèn)為APP Store

[UMessagesetChannel:nil];

消息處理方法

//向友盟注冊(cè)deviceToken

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

//打印deviceToken

NSLog(@"%@",[[[[deviceToken description]stringByReplacingOccurrencesOfString:@"<"withString:@""]stringByReplacingOccurrencesOfString:@">"withString:@""]

stringByReplacingOccurrencesOfString:@" "withString:@""]);

//注冊(cè)deviceToken

[UMessageregisterDeviceToken:deviceToken];

}

//注冊(cè)遠(yuǎn)程通知失敗

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

NSLog(@"注冊(cè)推送失敗,具體錯(cuò)誤:%@",error);

}

//收到推送消息時(shí)調(diào)用

-(void)application:(UIApplication*)application didReceiveRemoteNotification:(NSDictionary*)userInfo{

[UMessagedidReceiveRemoteNotification:userInfo];

}

如果需要關(guān)閉推送,使用[UMessage unregisterForRemoteNotifications]

4.測試與調(diào)試

由于使用的是開發(fā)環(huán)境,所以推送的時(shí)候,需要在友盟注冊(cè)的應(yīng)用中添加一個(gè)測試設(shè)備用來測試。將前面的代碼集成到項(xiàng)目里以后,使用真機(jī)運(yùn)行項(xiàng)目,提示注冊(cè)成功后可以在debug信息中看到獲取的DeviceToken,將DeviceToken拷貝下來備用。

得到DeviceToken后進(jìn)入友盟網(wǎng)站,依次執(zhí)行下面的操作:

消息推送->立即使用->(你的應(yīng)用)->開發(fā)環(huán)境->測試設(shè)備->添加測試設(shè)備

設(shè)備添加完成后就可以進(jìn)行推送調(diào)試了,在測試消息中點(diǎn)擊新建測試消息:

參數(shù)和提醒方式自行設(shè)置,發(fā)送方式選擇單播,輸入設(shè)備的DeviceToken,完成后提交即可:

確認(rèn)后等待推送消息發(fā)送即可




至此,消息推送功能基本完成,更多功能請(qǐng)移步友盟iOS SDK集成指南。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

推薦閱讀更多精彩內(nèi)容