本來打算用友盟推送的,但是發現友盟的集成稍微繁瑣了些,代碼多了些。算了,還是換回大名鼎鼎的極光推送吧,廢話不多說,進入正題。
上代碼:
AppDelegate.m
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
self.window = [[UIWindow alloc] initWithFrame:[[UIScreen mainScreen] bounds]];
[self.window makeKeyAndVisible];
// Required
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
NSString *plistPath = [[NSBundle mainBundle] pathForResource:@"PushConfig" ofType:@"plist"];
NSDictionary *dic = [[NSDictionary alloc] initWithContentsOfFile:plistPath];
[JPUSHService setupWithOption:launchOptions appKey:dic[@"APP_KEY"] channel:dic[@"CHANNEL"] apsForProduction:NO];
return YES;
}
- (void)application:(UIApplication *)application didReceiveRemoteNotification:(NSDictionary *)userInfo {
// Required,For systems with less than or equal to iOS6
[JPUSHService handleRemoteNotification:userInfo];
}
- (void)application:(UIApplication *)application didReceiveRemoteNotification:(NSDictionary *)userInfo fetchCompletionHandler:(void (^)(UIBackgroundFetchResult))completionHandler {
// IOS 7 Support Required
[JPUSHService handleRemoteNotification:userInfo];
completionHandler(UIBackgroundFetchResultNewData);
}
- (void)application:(UIApplication *)application didFailToRegisterForRemoteNotificationsWithError:(NSError *)error {
//Optional
NSLog(@"did Fail To Register For Remote Notifications With Error: %@", error);
}
- (void)application:(UIApplication *)application didRegisterForRemoteNotificationsWithDeviceToken:(NSData *)deviceToken {
// Required
[JPUSHService registerDeviceToken:deviceToken];
// *****星標1*******
[JPUSHService setTags:[NSSet setWithObjects:@"test", nil] alias:@"ZhangQian" callbackSelector:@selector(tagsAliasCallback:tags:alias:) object:self];
// *****星標1*******
}
// *****星標2*******
-(void)tagsAliasCallback:(int)iResCode
tags:(NSSet*)tags
alias:(NSString*)alias
{
NSLog(@"rescode: %d, \\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\ntags: %@, \\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\nalias: %@\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\n", iResCode, tags , alias);
}
// *****星標2*******
在官方集成文檔里是沒有上面星標1和星標2里的東東的,在這里說一下,為毛要弄這個東東,其實這個是給客戶端取一個標簽(tag)、別名(alias),為了標識這個客戶端。標識客戶端是為了服務器端推送的時候可以選擇性推送,比如QQ,你跟我聊天,那么只推送給我手機上的這個客戶端,而不是所有客戶端。標簽可以取若干個,別名只能取一個。如果不想取那就給一個nil。
框框中“test”就是標簽,“ZhangQian”就是別名。每次調用這個方法,只會覆蓋之前你設置的標簽或別名,而不是增加,callbackSelector就是向服務器請求設置標簽和別名的回調,告訴你有沒有成功。在星標2中,如果rescode=0那就是成功了,否則失敗。
除了標簽、別名可以標識客戶端外,還有一個標識就是registrationID,registrationID可以通過 [JPUSHService registrationID]這樣來獲取,當客戶端第一次向jpush注冊成功后,jpush服務器會返回一個設備唯一標識,就是這個registrationID。registrationID可以在app的任何地方獲取。
丫的弄這么多標識干jb毛啊,那咱就說說這三個標識的區別:
標簽(tag):可以設置多個,類似搜索的關鍵字,也就是可以用多個關鍵字來給某些客戶端做標記。可以多個客戶端有相同的標簽,這時候推送就會推送給多個客戶端。
別名(alias):只可以設置一個,同樣存在多個客戶端擁有相同的別名的情況,同上也是推送給多個客戶端。
registrationID:是唯一標識,每個客戶端擁有唯一的registrationID,推送也是單一推送。
所以,攻城獅們可以根據不同的需求來使用以上三個標識,如果沒有特殊的需求,registrationID就足夠了。把registrationID返回給你客戶端自己的服務器維護起來。你的服務器想給哪個客戶端推送了就用這個registrationID。
剛剛lz腦洞大開,發現別名還是很有用的,如果我給每個客戶端的別名取名為當前版本號,那么,對于那些沒有升級的客戶端,我就可以給低版本號別名的客戶端人推送消息,告訴他及時升級。嗯~~不錯
還有,這三個標識在極光控制臺測試的使用,如下圖:
我擦,我居然扯了這么遠,而且還少說了兩個事,別忘了在你項目的次根目錄加一個PushConfig.plist。跟Info.plist在同一目錄下,把你極光后臺的APP_KEY寫到里邊去。APS_FOR_PRODUCTION為0就是開發模式,1就是生產模式,一定要跟你的項目的debug(0)和release(1)對應上。CHANNEL就填app store就行。
然后就是jpush是走http協議的,所以一定要讓你的app支持http協議(iOS9后默認https)。在Info.plist中添加NSAppTransportSecurity類型Dictionary。在NSAppTransportSecurity下添加NSAllowsArbitraryLoads類型Boolean,值設為YES。
還有最后一件事就是把Background Modes下的Remote notifications選中。因為我在弄的時候發現它不是打開的,所以大家還是注意下
JPush SDK下載:http://docs.jpush.io/resources/