IOS 推送,极光推送,推送到指定页面

今天朋友说到推送,因为以前也没做过,就跟着看了看极光的推送.(自己的每一步,很详细,很啰嗦..大神就不用看了...)
2016-12-15更新了跳转到指定页面代码--第二部分

我是直接用了我们自己的发布证书,在发布证书的基础上做的推送证书,如果说还没有做任何证书,或者准备做测试证书使用的,可以点击看极光的文档一步步做,其中虽然有部分不同,但大致方向还是对的.证书配置链接
1.设置推送证书

IOS 推送,极光推送,推送到指定页面_第1张图片

1-1

选择对应的app,如果之前没有推送证书的话,Push 那一栏应该是灰的.然后点击Edit

IOS 推送,极光推送,推送到指定页面_第2张图片

1-2

这里和我的可能不一样,开发环境选上面的,生产环境就点下面的.点击Create Certificate.

IOS 推送,极光推送,推送到指定页面_第3张图片

1-3

continue;

IOS 推送,极光推送,推送到指定页面_第4张图片

1-4

这里需要在自己电脑上做一个CSR证书.
打开电脑的钥匙串访问

IOS 推送,极光推送,推送到指定页面_第5张图片

1-5

IOS 推送,极光推送,推送到指定页面_第6张图片

1-6

邮件地址,常用名称随便填,然后选择存储到磁盘,存到本地,在1-4里选择,然后上传给苹果.

IOS 推送,极光推送,推送到指定页面_第7张图片

1-7

生产成功,下载到本地.双击打开.
2.生成P12,传给极光
双击打开下载的证书

2-1

应该是apple push 开头的.右键,导出.

IOS 推送,极光推送,推送到指定页面_第8张图片

2-2

名字随便起,尽量不用汉字.最后一项要选择.p12.然后存储好.(密码随便起一个,简单点,一会要用到)
3.在极光创建应用,上传p12文件.融SDK.

IOS 推送,极光推送,推送到指定页面_第9张图片

3-1

因为我只做了生产证书,没有用开发证书,所以选择ios生产证书,把刚生产的p12,上传,密码就填刚刚的密码.然后创建.
下载极光的SDK极光SDK下载地址
解压之后只需要lib内东西,将整个lib拖动到项目内

IOS 推送,极光推送,推送到指定页面_第10张图片

3-2

记得要选groups啊!!!
然后入一堆库:
CFNetwork.framework
CoreFoundation.framework
CoreTelephony.framework
SystemConfiguration.framework
CoreGraphics.framework
Foundation.framework
UIKit.framework
Security.framework
Xcode7需要的是libz.tbd;Xcode7以下版本是libz.dylib
Adsupport.framework (获取IDFA需要;如果不使用IDFA,请不要添加)
然后在AppDelegate入口类里进行注册.(我自己写了一个方法,记得要调用啊....)

import"JPUSHService.h"

IOS 推送,极光推送,推送到指定页面_第11张图片

3-3

advertisingId这个我换了,极光的代码里的报错了直接,我用自己找的方法,反正就是个唯一标识.
最后的方法里,Option:后面我写的nil,因为文档里也没接受,不知道是什么意思,(反正写nil也能用).
appKey是在极光创建应用之后极光给的.填自己的就行了.channel:0是开发证书,1是生产.我的发布选1.apsForProduction:是否生产环境.我的是yes.
后面还有几个代理方法,代码(省略掉了很多空格....最后还是要记得调用jPush方法啊....):

pragma mark -极光推送

-(void)jPush
{
NSString*advertisingId = [[UIDevicecurrentDevice].identifierForVendorUUIDString];
//Required
if([[UIDevicecurrentDevice].systemVersionfloatValue] >=8.0) {
//可以添加自定义categories
[JPUSHServiceregisterForRemoteNotificationTypes:(UIUserNotificationTypeBadge|
UIUserNotificationTypeSound|
UIUserNotificationTypeAlert)
categories:nil];
}else{
//categories必须为nil
[JPUSHServiceregisterForRemoteNotificationTypes:(UIRemoteNotificationTypeBadge|
UIRemoteNotificationTypeSound|
UIRemoteNotificationTypeAlert)
categories:nil];
}
//Required
//如需继续使用pushConfig.plist文件声明appKey等配置内容,请依旧使用[JPUSHService setupWithOption:launchOptions]方式初始化。
[JPUSHServicesetupWithOption:nilappKey:@"你自己的APPKEY"
channel:@"1"
apsForProduction:YES
advertisingIdentifier:advertisingId];
}

  • (void)application:(UIApplication)application
    didRegisterForRemoteNotificationsWithDeviceToken:(NSData
    )deviceToken {
    /// Required -注册DeviceToken
    [JPUSHServiceregisterDeviceToken:deviceToken];
    }
  • (void)application:(UIApplication)application didReceiveRemoteNotification:(NSDictionary)userInfo {
    // Required,For systems with less than or equal to iOS6
    [JPUSHServicehandleRemoteNotification:userInfo];
    }
  • (void)application:(UIApplication)application didReceiveRemoteNotification:(NSDictionary)userInfo fetchCompletionHandler:(void(^)(UIBackgroundFetchResult))completionHandler {
    // IOS 7 Support Required
    [JPUSHServicehandleRemoteNotification:userInfo];
    completionHandler(UIBackgroundFetchResultNewData);
    }
  • (void)application:(UIApplication)application didFailToRegisterForRemoteNotificationsWithError:(NSError)error {
    //Optional
    NSLog(@"did Fail To Register For Remote Notifications With Error: %@", error);
    }

4.真机运行
在真机上运行,没有问题的话,就到极光官网上发送一个推送,向全体人发的...测试了一下,看下最后效果

IOS 推送,极光推送,推送到指定页面_第12张图片

4-1

-----------------------补充-------------------------
Xcode8之后还要有一步

IOS 推送,极光推送,推送到指定页面_第13张图片

5-1

这个push要打开,否则会获取不到deviceToken;

/-----------------第二部分---推送到指定页面------------------/#

1.首先是创建了开发者证书(因为之前我直接先做的发布证书),步骤和前面的发布证书的创建是一样的.
2.创建完成下载到本地,然后生成p12传给极光,步骤也和上面是一样的.
3.在appdelegate里注册极光的时候之前有一个是YES,暂时要先改为NO,因为要先调试,最后上架前再改回来,如图

IOS 推送,极光推送,推送到指定页面_第14张图片

2-3-1

然后连接真机,运行下你的程序,极光会打印出来log,会有真机的id,这个用于你后续的调试.

2-3-2

记住这个ID,然后在极光推送中心填写真机ID,测试下是否真的只发送到你的手机推送,如图.成功后才能继续.

IOS 推送,极光推送,推送到指定页面_第15张图片

2-3-3

4.在appdelegate里有两个方法

- (void)application:(UIApplication*)application didReceiveRemoteNotification:(NSDictionary*)userInfo
{
//1号方法

/**---当app在后台或者被关闭时,发送推送会调用这个方法(不确定)----*/
    
    // Required,For systems with less than or equal to iOS6
    [JPUSHService handleRemoteNotification:userInfo];
    
    
    if (application.applicationState == UIApplicationStateActive)
    {
        NSDictionary *aps = userInfo[@"aps"];
        NSString *newstitle = aps[@"alert"];
        //这里写APP正在运行时,推送过来消息的处理
        UIAlertView *al = [[UIAlertView alloc]initWithTitle:@"新消息" message:newstitle delegate:self cancelButtonTitle:@"取消" otherButtonTitles:@"查看", nil];
        al.tag = 100;
        [al show];
       
        
        
    } else if (application.applicationState == UIApplicationStateInactive ) {
        
        //APP在后台运行,推送过来消息的处理
        [self goToMssageViewControllerWith:userInfo];
        
        
        
    } else if (application.applicationState == UIApplicationStateBackground) {
        
        //APP没有运行,推送过来消息的处理
        [self goToMssageViewControllerWith:userInfo];
        
    }
}
- (void)application:(UIApplication*)application didReceiveRemoteNotification:(NSDictionary*)userInfo fetchCompletionHandler:(void(^)(UIBackgroundFetchResult))completionHandler 
{
//2号方法

/**---当app在运行时,发送推送会调用这个方法(不确定)----*/
    // IOS 7 Support Required
    [JPUSHService handleRemoteNotification:userInfo];
    completionHandler(UIBackgroundFetchResultNewData);
   
    if (application.applicationState == UIApplicationStateActive)
    {
        
        NSDictionary *aps = userInfo[@"aps"];
        NSString *newstitle = aps[@"alert"];
        //这里写APP正在运行时,推送过来消息的处理
        UIAlertView *al = [[UIAlertView alloc]initWithTitle:@"新消息" message:newstitle delegate:self cancelButtonTitle:@"取消" otherButtonTitles:@"查看", nil];
        al.tag = 100;
        [al show];
       
        
    } else if (application.applicationState == UIApplicationStateInactive ) {
        
        //APP在后台运行,推送过来消息的处理
        [self goToMssageViewControllerWith:userInfo];
        
        
    } else if (application.applicationState == UIApplicationStateBackground) {
        
        //APP没有运行,推送过来消息的处理
        [self goToMssageViewControllerWith:userInfo];
    }
}

这里特别说明一下,我在方法1和方法2里将三种情况都写了,但实际上我在网上搜到的是方法1适用于app运行时调用,而我实际测试正好与搜到的相反,所有我将两种方法里各个情况都写上了,到底如何你可以自己试试##

5.gotomessage的方法



//跳转方法

- (void)goToMssageViewControllerWith:(NSDictionary*)msgDic
{
    NSString *type = msgDic[@"type"];    
    if([type isEqualToString:@"news"])
    {
        /**---新闻---*/
        NSString *newsId  = msgDic[@"newsId"];
        
        ZXNewDetailVC *fcdVC = [[ZXNewDetailVC alloc]init];
        fcdVC.msgId = [NSString stringWithFormat:@"information/getBytype.html?id=%@",newsId];
        [self.window.rootViewController presentViewController:fcdVC animated:YES completion:nil];
         
    }
 
    else
    {
        NSLog(@"others");
    }
    
}

这里的type,news,newsId,都是我自己在发推送的时候定义的,你可以根据自己app的实际需要更改,建议先打印一下msgDic看一下数据机构.在发送的时候我的如图所示,

IOS 推送,极光推送,推送到指定页面_第16张图片
Paste_Image.png

你可能感兴趣的:(IOS 推送,极光推送,推送到指定页面)