本来打算用友盟推送的,但是发现友盟的集成稍微繁琐了些,代码多了些。算了,还是换回大名鼎鼎的极光推送吧,废话不多说,进入正题。
上代码:
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/