学习连接:ios
详细步骤:框架
1.进入文档-JPush推送应用中心:https://www.jpush.cn/common/apps/less
2.建立应用:这一步有两个两个证书:一个是开发推送证书和上架应用推送证书,这两个证书配置后面会详细讲解(容易错误地方)ide
3.下载SDK,文档也说到(将SDK包解压,在XCode中选择“Add files to 'Your project name'...”,将解压后的lib子文件夹(包含JPUSHService.h、jpush-ios-x.x.x.a)添加到你的工程目录中。)学习
4.导入必要框架:(fetch
CFNetwork.frameworkui
CoreFoundation.frameworkspa
CoreTelephony.frameworkcode
SystemConfiguration.framework
CoreGraphics.framework
Foundation.framework
UIKit.framework
Security.framework
Xcode7须要的是libz.tbd;Xcode7如下版本是libz.dylib
)
5.
2.1.0以前版本是经过plist文件配置,这个我就不截图讲解了,只要建立一个plist文件,增长三个字段就能够了,文档上有,一键copy便可了
可是咱们如今是能够经过一个方法直接配置的,方法以下:
/*! * @abstract 启动SDK * * @param launchingOption 启动参数. * @param appKey 一个JPush 应用必须的,惟一的标识. 请参考 JPush 相关说明文档来获取这个标识. * @param channel 发布渠道. 可选. * @param isProduction 是否生产环境. 若是为开发状态,设置为 NO; 若是为生产状态,应改成 YES. * * @discussion 提供SDK启动必须的参数, 来启动 SDK. * 此接口必须在 App 启动时调用, 不然 JPush SDK 将没法正常工做. */ [JPUSHService setupWithOption:launchOptions appKey:kJPUSHAppKey channel:kJPUSHChannel apsForProduction:isProduction];
5.添加代码:
2.1.0版本开始,API类名为JPUSHService,再也不使用原先的APService。
若是用的是Xcode7时,须要在App项目的plist手动加入如下key和值以支持http传输:
<key>NSAppTransportSecurity</key> <dict> <key>NSAllowsArbitraryLoads</key> <true/> </dict>
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions { self.window = [[[UIWindow alloc] initWithFrame:[[UIScreen mainScreen] bounds]] autorelease]; self.window.backgroundColor = [UIColor whiteColor]; [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 //如需兼容旧版本的方式,请依旧使用[JPUSHService setupWithOption:launchOptions]方式初始化和同时使用pushConfig.plist文件声明appKey等配置内容。 [JPUSHService setupWithOption:launchOptions appKey:appKey channel:channel apsForProduction:isProduction]; return YES; }
- (void)application:(UIApplication *)application didRegisterForRemoteNotificationsWithDeviceToken:(NSData *)deviceToken { // Required [JPUSHService registerDeviceToken:deviceToken]; } - (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); }
6.配置这个地方,否则运行就会有问题
7.进入极光中心:https://www.jpush.cn/push/apps/0942889e8d623bf81d7c185a/push/notification/sent/
选择你的应用-推送-发送通知-完成了(注意只有当你的程序不在前台的时候才会显示通知的哦)
8.配置证书那一块,我后期会给大家详解的,保证你会一次,永远都会的配置证书的哦!关注我博客之后,到时候会及时提醒到你的哦!
9.到时候还给你们一并讲解一下本地推送,超简单超详细!让你们在工做当中再也不加班,轻轻松松开发ios,让咱们赢取白富美,不在穷屌丝,😄!
10:极光配置成功标志:
10-1:是发送通知不是自定义信息:以前卡在这里,一只收不到通知,害我从头配置一遍
10-2:在这个方法里执行,可让用户在前台app中显示咱们推送的消息
// 在这个方法里面打印userinfo数据有两种状况:
1:当用户在后台的时候,咱们发送通知,他点击通知消息进入咱们app里面,这时候会掉用下面这个方法,打印userinfo的数据出来,能够作一些跳转操做
2:当用户在前台的时候,咱们发送通知,可让用户看到咱们的信息,可是也是掉用这个方法,打印userinfo的数据的
疑惑点:当用户在后台看到咱们推送的通知消息,可是不是从推送消息哪里进入的话,而是直接从点击app进去的话,这时候是不会调用下面这个方法,也就不打印数据了,天然只能进入首页了,也就不存在跳转不一样页面的判断了
- (void)application:(UIApplication *)application didReceiveRemoteNotification:(NSDictionary *)userInfo fetchCompletionHandler:(void (^)(UIBackgroundFetchResult))completionHandler { // IOS 7 Support Required [JPUSHService handleRemoteNotification:userInfo]; completionHandler(UIBackgroundFetchResultNewData); // 应用正处理前台状态下,不会收到推送消息,所以在此处须要额外处理一下 if (application.applicationState == UIApplicationStateActive) { UIAlertView *alert = [[UIAlertView alloc] initWithTitle:@"收到推送消息" message:userInfo[@"aps"][@"alert"] delegate:nil cancelButtonTitle:@"取消" otherButtonTitles:@"肯定", nil]; [alert show]; } }
userInfo--{ "_j_msgid" = 3563975788; aps = { alert = 7; badge = 1; sound = default; }; }
10-3:解决后台里面app上右上角badge数量清空的方法
#pragma mark - 设置小红点,回到后台就会清空推送消息 - (void)applicationWillEnterForeground:(UIApplication *)application { [application setApplicationIconBadgeNumber:0]; [application cancelAllLocalNotifications]; }
10-4:程序在没有运行的状况下,也是能够接受通知的,