[一句秒懂]极光推送(激光)

  1. 学习连接ios

    http://docs.jpush.io/guideline/ios_guide/ app

  2. 详细步骤:框架

    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.

建立并配置PushConfig.plist文件有两种方式:

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:程序在没有运行的状况下,也是能够接受通知的,

相关文章
相关标签/搜索