iOS极光推送,2016最新配置教程

废话不多说,进入正题。

上代码:

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脑洞大开,发现别名还是很有用的,如果我给每个客户端的别名取名为当前版本号,那么,对于那些没有升级的客户端,我就可以给低版本号别名的客户端人推送消息,告诉他及时升级。嗯~~不错

还有,这三个标识在极光控制台测试的使用,如下图:

iOS极光推送,2016最新配置教程_第1张图片

我擦,我居然扯了这么远,而且还少说了两个事,别忘了在你项目的次根目录加一个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选中。因为我在弄的时候发现它不是打开的,所以大家还是注意下

iOS极光推送,2016最新配置教程_第2张图片

JPush SDK下载:http://docs.jpush.io/resources/


你可能感兴趣的:(iOS极光推送,2016最新配置教程)