首页 > 代码库 > iOS PushMebaby

iOS PushMebaby

PushMebaby是测试远程推送是否可用的第三方框架

使用方法:

1.上github下载PushMebaby的源码

2.在本地尝试编译PushMebaby,可能会有Error

解决方法:把抛Error对应的代码 注释掉

//#include <CoreServices/../Frameworks/CarbonCore.framework/Headers/MacTypes.h>

3.在ApplicationDelegate.m填写deviceToken和certificate

  3.1 self.deviceToken = @"XXXXXXXXXXXXXXXXXXXXXXXXXXX";

  3.2把远程推送的开发证书,拖入项目,改名为apns.cer

4.运行PushMebaby

  4.1勾选"总是允许"

  技术分享

  4.2 PushMebaby是mac,在下图弹出框中点击send

  技术分享

5.补充Payload知识

payload的格式,可在苹果官方文档搜"Examples of JSON Payloads",有多种格式,下面是其中一种

{    "aps" : {        "alert" : {            "body" : "Bob wants to play poker",            "action-loc-key" : "PLAY"        },        "badge" : 5,    },    "diyInfo" : {          "xxx" : "xxxx",          "xxxx" : "xxxxxx",    }}

注:aps是不可以改的

要使远程推送的消息,附带额外的信息,可以在aps外面添加,例如上面的diyInfo

6.客户端接收到远程推送通知之后的解析工作

  6.1 aps里的信息,苹果自己会解析

  6.2 aps之外的信息,需要iOS开发自己解析

    6.2.1 场景一:在用户手机里,应用处于运行状态(双击home键,可以看到进程管理中看到)

    接收到远程推送消息,程序会自动调用AppDelegate.m里下面这个代理方法

    - (void)application:(UIApplication *)application didReceiveRemoteNotification:(NSDictionary *)userInfo

    {

          // 参数userInfo就是上面提到的diyInfo

          NSLog(@"%@",userInfo);

    }

     

    6.2.2 场景二:在用户手机里,没有运行我们的应用

    接收到远程推送消息,程序会自动调用下面的方法

    - (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions

    {

          // info是payload的全部信息

          NSDictionary *info = launchOptions[UIApplicationLaunchOptionsRemoteNotificationKey];

      }

 

 

iOS PushMebaby