關(guān)于iOS中的推送, 我們使用最多的可能就是極光了, 關(guān)于極光推送, 這里不做過(guò)多的介紹, 可到其官網(wǎng)進(jìn)行學(xué)習(xí), 這里主要是介紹集成的大致過(guò)程.
一. 創(chuàng)建推送證書(shū)
1.1. 創(chuàng)建 APP ID
登陸蘋果開(kāi)發(fā)者中心developer.apple.com, 進(jìn)入后臺(tái):
選擇Certificates, Identifiers&Profiles, 然后選擇Identifiers下的App IDs , 右側(cè)右上角 "+", 新建一個(gè)APP ID:
下一步, 這里給你的ID 設(shè)置一個(gè)名字, 便于記憶就好:
注意: 這里的APP ID Suffix, 一定要選擇Explicit App ID(精確型), 不要選擇下面的通配型(Wildcard App ID), 一般直接使用項(xiàng)目的 Bundle Identifier即可;
下面的App Services, 勾選Push Notifications:
然后, 根據(jù)頁(yè)面提示繼續(xù), 完成即可;
PS: 如果是已有的APP ID 可點(diǎn)擊下面的Edit, 來(lái)勾選 Push Notifications
1.2 創(chuàng)建推送證書(shū)
然后選擇Certificates下的 all, 點(diǎn)擊右側(cè)右上角 "+", 新建一個(gè)證書(shū):
然后來(lái)到下面這個(gè)界面, 選擇你需要?jiǎng)?chuàng)建的證書(shū)類型:
Development下的:
Apple Push Notification service SSL (Sandbox) :測(cè)試環(huán)境下的推送證書(shū)
Production下的:
Apple Push Notification service SSL (Sandbox & Production): 發(fā)布環(huán)境, 推送證書(shū)
最好兩種證書(shū)都創(chuàng)建一個(gè), 一個(gè)用于測(cè)試, 一個(gè)用于發(fā)布;
然后來(lái)到:
這里選擇剛剛創(chuàng)建的含有推送服務(wù) 的 App ID
繼續(xù), 下個(gè)頁(yè)面,不用設(shè)置, 接下來(lái)會(huì)來(lái)到:
這里需要使用電腦的鑰匙串訪問(wèn)來(lái)請(qǐng)求一個(gè)證書(shū),:
填寫相關(guān)信息:
這里選擇的保存到磁盤, 所以上面的郵箱可以隨便寫, 建議選擇保存到磁盤, 然后選擇個(gè)保存位置, 即可!
然后,回到證書(shū)申請(qǐng)頁(yè)面, 選擇剛剛使用鑰匙串創(chuàng)建的請(qǐng)求證書(shū), 下一步:
Download這個(gè)新的證書(shū), 雙擊, 安裝到鑰匙串, 然后打開(kāi)鑰匙串:
上面選擇登錄, 下面選擇我的證書(shū), 然后在右側(cè)就能找到你剛剛安裝的證書(shū), 導(dǎo)出:
選擇保存位置, 設(shè)置文件名稱, 文件格式, 一定要選擇個(gè)人信息交換(.p12)
點(diǎn)擊存儲(chǔ)的時(shí)候, 會(huì)彈出設(shè)置密碼的界面, 這里的密碼一定要設(shè)置,而且不能忘記, 安裝彈框提示, 至完成即可!
這樣, 桌面上就要我們?cè)O(shè)置好的p12文件, 也就是我們配置好的推送證書(shū).
二. 在極光平臺(tái)創(chuàng)建應(yīng)用
要想使用極光的服務(wù), 需要注冊(cè)成為極光的開(kāi)發(fā)者.這里可在其官網(wǎng)進(jìn)行注冊(cè), 然后進(jìn)入控制臺(tái):
在應(yīng)用管理中創(chuàng)建一個(gè)應(yīng)用:
設(shè)置應(yīng)用名稱, 選擇應(yīng)用圖標(biāo):
下面的Android不用管, 直接來(lái)到iOS
需要注意的是: 這里的證書(shū)密碼必須要設(shè)置, 我之前導(dǎo)出時(shí)沒(méi)有設(shè)置密碼, 這里直接什么都沒(méi)填, 但是認(rèn)證一直不能通過(guò), 所以要設(shè)置密碼;
然后, 創(chuàng)建我的應(yīng)用, 即可;我們就獲取到了AppKey;
在最后彈出的頁(yè)面中, 我們可以查看證書(shū)是否可用:
可以看到, 我這里的開(kāi)發(fā)環(huán)境的證書(shū)狀態(tài)是已驗(yàn)證, 就是可用的, 成產(chǎn)環(huán)境的證書(shū)我沒(méi)有上傳, 所以此處的狀態(tài)是未上傳, 點(diǎn)擊左側(cè)的?, 可以查看各個(gè)狀態(tài)的含義:
三. 配置Xcode
3.1 集成SDK
首先在官網(wǎng)下載SDK, 將解壓后的文件夾中的Lib 文件夾拖入到你的項(xiàng)目中:
有下面這三個(gè)文件:
然后, 添加系統(tǒng)依賴庫(kù):
添加系統(tǒng) Framework
- CFNetwork.framework
- CoreFoundation.framework
- CoreTelephony.framework
- SystemConfiguration.framework
- CoreGraphics.framework
- Foundation.framework
- UIKit.framework
- Security.framework
- libz.tbd (Xcode7以下版本是libz.dylib)
- AdSupport.framework (獲取IDFA需要织阳;如果不使用IDFA,請(qǐng)不要添加)
- UserNotifications.framework (Xcode8及以上)
- libresolv.tbd (JPush 2.2.0及以上版本需要, Xcode7以下版本是libresolv.dylib)
3.2 開(kāi)啟Push Notifications
來(lái)到Xcode的Capabilities, 打開(kāi)Push Notifications, 如果是首次打開(kāi), 可能會(huì)彈出一個(gè)界面, 讓你選擇開(kāi)發(fā)者賬號(hào), 選擇你創(chuàng)建推送證書(shū)那個(gè)賬號(hào)即可, 完成后如下圖所示:
3.3 關(guān)于網(wǎng)絡(luò)訪問(wèn)權(quán)限
不過(guò), 就要全面使用ATS, 所以這個(gè)操作, 以后可能就不行了:
在info.plist文件添加NSAppTransportSecurity, 類型為字典 , 然后添加一個(gè)key: NSAllowsArbitraryLoads, 類型bool, 值為: YES,即可;
注意: 對(duì)于JPush 2.1.9 及以上的版本是支持ATS訪問(wèn)的, 所以在使用大于2.1.9版本的JPushSDK的時(shí)候, 不需要進(jìn)行這個(gè)設(shè)置了, 這里使用的是3.0版本, 所以不需配置這一項(xiàng).
3.4 使用API
以下只是極光推送文檔中的實(shí)例代碼!!!
在項(xiàng)目AppDelegate, 添加以下代碼:
// 引入JPush功能所需頭文件
#import "JPUSHService.h"
// iOS10注冊(cè)APNs所需頭文件
#ifdef NSFoundationVersionNumber_iOS_9_x_Max
#import <UserNotifications/UserNotifications.h>
#endif
并實(shí)現(xiàn)代理:
@interface AppDelegate ()<JPUSHRegisterDelegate>
@end
在
-(BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions注冊(cè)極光推送:
//Required
//notice: 3.0.0及以后版本注冊(cè)可以這樣寫采呐,也可以繼續(xù)用之前的注冊(cè)方式
JPUSHRegisterEntity * entity = [[JPUSHRegisterEntity alloc] init];
entity.types = JPAuthorizationOptionAlert|JPAuthorizationOptionBadge|JPAuthorizationOptionSound;
if ([[UIDevice currentDevice].systemVersion floatValue] >= 8.0) {
// 可以添加自定義categories
// NSSet<UNNotificationCategory *> *categories for iOS10 or later
// NSSet<UIUserNotificationCategory *> *categories for iOS8 and iOS9
}
[JPUSHService registerForRemoteNotificationConfig:entity delegate:self];
// Required
// init Push
// notice: 2.1.5版本的SDK新增的注冊(cè)方法蹬叭,改成可上報(bào)IDFA荔燎,如果沒(méi)有使用IDFA直接傳nil
// 如需繼續(xù)使用pushConfig.plist文件聲明appKey等配置內(nèi)容贪绘,請(qǐng)依舊使用[JPUSHService setupWithOption:launchOptions]方式初始化炎咖。
[JPUSHService setupWithOption:launchOptions appKey:appKey
channel:channel
apsForProduction:isProduction
advertisingIdentifier:advertisingId];
上面的方法中的幾個(gè)參數(shù), 官方的解釋是這樣的:
- appKey :極光管理后臺(tái)創(chuàng)建應(yīng)用后自動(dòng)生成的AppKey值绍哎。請(qǐng)確保應(yīng)用內(nèi)配置的 AppKey 與 Portal 上創(chuàng)建應(yīng)用后生成的 AppKey 一致来农。
- channel : 指明應(yīng)用程序包的下載渠道,為方便分渠道統(tǒng)計(jì)崇堰,具體值由你自行定義沃于,如:App Store。
- apsForProduction : 1.3.1版本新增海诲,用于標(biāo)識(shí)當(dāng)前應(yīng)用所使用的APNs證書(shū)環(huán)境繁莹。0 (默認(rèn)值)表示采用的是開(kāi)發(fā)證書(shū),1 表示采用生產(chǎn)證書(shū)發(fā)布應(yīng)用特幔。
注:此字段的值要與Build Settings的Code Signing配置的證書(shū)環(huán)境一致咨演。- advertisingIdentifier : IDFA 廣告標(biāo)示符
實(shí)現(xiàn)系統(tǒng)推送代理方法:
// 注冊(cè)APNs成功并上報(bào)DeviceToken
- (void)application:(UIApplication *)application
didRegisterForRemoteNotificationsWithDeviceToken:(NSData *)deviceToken {
/// Required - 注冊(cè) DeviceToken
[JPUSHService registerDeviceToken:deviceToken];
}
// 實(shí)現(xiàn)注冊(cè)APNs失敗接口(可選)
- (void)application:(UIApplication *)application didFailToRegisterForRemoteNotificationsWithError:(NSError *)error {
//Optional
NSLog(@"did Fail To Register For Remote Notifications With Error: %@", error);
}
實(shí)現(xiàn)JPUSHRegisterDelegate 相關(guān)代理方法, 處理通知回調(diào)方法
#pragma mark- JPUSHRegisterDelegate
// iOS 10 Support
- (void)jpushNotificationCenter:(UNUserNotificationCenter *)center willPresentNotification:(UNNotification *)notification withCompletionHandler:(void (^)(NSInteger))completionHandler {
// Required
NSDictionary * userInfo = notification.request.content.userInfo;
if([notification.request.trigger isKindOfClass:[UNPushNotificationTrigger class]]) {
[JPUSHService handleRemoteNotification:userInfo];
}
completionHandler(UNNotificationPresentationOptionAlert); // 需要執(zhí)行這個(gè)方法,選擇是否提醒用戶蚯斯,有Badge薄风、Sound、Alert三種類型可以選擇設(shè)置
}
// iOS 10 Support
- (void)jpushNotificationCenter:(UNUserNotificationCenter *)center didReceiveNotificationResponse:(UNNotificationResponse *)response withCompletionHandler:(void (^)())completionHandler {
// Required
NSDictionary * userInfo = response.notification.request.content.userInfo;
if([response.notification.request.trigger isKindOfClass:[UNPushNotificationTrigger class]]) {
[JPUSHService handleRemoteNotification:userInfo];
}
completionHandler(); // 系統(tǒng)要求執(zhí)行這個(gè)方法
}
- (void)application:(UIApplication *)application didReceiveRemoteNotification:(NSDictionary *)userInfo fetchCompletionHandler:(void (^)(UIBackgroundFetchResult))completionHandler {
// Required, iOS 7 Support
[JPUSHService handleRemoteNotification:userInfo];
completionHandler(UIBackgroundFetchResultNewData);
}
- (void)application:(UIApplication *)application didReceiveRemoteNotification:(NSDictionary *)userInfo {
// Required,For systems with less than or equal to iOS6
[JPUSHService handleRemoteNotification:userInfo];
}
然后, 在真機(jī)上, 測(cè)試,控制臺(tái)輸出包含以下信息的log, 說(shuō)明已成功集成:
--------------------------- JPush Log ----------------------------
--------------------JPush SDK Version:3.0.0--build:13----------
--------------------JCore Lib Version:1.0.0------------
-----------------AppKey:e7f56fsafssdd61f72de59a----------------
----------------------------------------------------------------
四. 測(cè)試發(fā)送
來(lái)到極光的開(kāi)發(fā)者服務(wù)后臺(tái), 在應(yīng)用管理中找到你的應(yīng)用, 然后點(diǎn)擊進(jìn)入, 選擇推送-->發(fā)送通知:
這里編輯需要發(fā)送的內(nèi)容;
然后, 選擇推送對(duì)象:
這里選擇的是開(kāi)發(fā)環(huán)境和所有人, 然后立即發(fā)送即可! 這樣, 你安裝了這個(gè)App的設(shè)備就會(huì)收到這一條推送信息:
以上便是最基本集成過(guò)程, 其他的業(yè)務(wù)需求, 可在此基礎(chǔ)上進(jìn)行相關(guān)邏輯的編寫.
此篇文章對(duì)應(yīng)的demo為:https://github.com/LQQZYY/LZJPush, 可以作為參考.