废话不多说,进入正题。
上代码:
AppDelegate.m
- (BOOL)application:(UIApplication*)application didFinishLaunchingWithOptions:(NSDictionary*)launchOptions {
self.window= [[UIWindowalloc] initWithFrame:[[UIScreenmainScreen] bounds]]; [self.windowmakeKeyAndVisible];// Requiredif([[UIDevicecurrentDevice].systemVersionfloatValue] >=8.0) {//可以添加自定义categories[JPUSHService registerForRemoteNotificationTypes:(UIUserNotificationTypeBadge|UIUserNotificationTypeSound|UIUserNotificationTypeAlert) categories:nil]; }else{//categories 必须为nil[JPUSHService registerForRemoteNotificationTypes:(UIRemoteNotificationTypeBadge|UIRemoteNotificationTypeSound|UIRemoteNotificationTypeAlert) categories:nil]; }// RequiredNSString*plistPath = [[NSBundlemainBundle] pathForResource:@"PushConfig"ofType:@"plist"];NSDictionary*dic = [[NSDictionaryalloc] initWithContentsOfFile:plistPath]; [JPUSHService setupWithOption:launchOptions appKey:dic[@"APP_KEY"] channel:dic[@"CHANNEL"] apsForProduction:NO];returnYES;
}
- (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 {//OptionalNSLog(@"did Fail To Register For Remote Notifications With Error: %@", error);}
- (void)application:(UIApplication*)application didRegisterForRemoteNotificationsWithDeviceToken:(NSData*)deviceToken {// Required[JPUSHService registerDeviceToken:deviceToken];// *****星标1*******[JPUSHService setTags:[NSSetsetWithObjects:@"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/