iOS 跳过服务器自己测试推送功能

当iOS端写好啦推送功能,而后台的小伙伴腾不出时间帮忙配合的时候,我们只有自己动手来测试自己的推送功能了

  • 关于如何创建推送证书,这里就不介绍了,直接从如何把p12转为pem文件开始

1.p12转pem (pem文件发给后台来进行推送)
- pem文件是服务器向苹果服务器做推送时候需要的文件,主要是做服务器的小伙伴们要用,下面介绍一下pem文件的生成。

  • 打开Keychain Access,在Certificates里面找到推送证书。分别将certificate和private key(私钥)导出得到.p12文件。
    例如:Apple Development Push Services > Export “Apple Development Push Services ID123”,保存为 apns-dev-cert.p12。
    对“Private Key”做同样操作,保存为 apns-dev-key.p12 文件。
  • 需要通过终端命令将这些文件转换为PEM格式:这里注意要用终端进入p12文件的目录中再执行下面的操作 直接复制下面的命令
    openssl pkcs12 -clcerts -nokeys -out apns-dev-cert.pem -in apns-dev-cert.p12 (导出证书的pem)
    openssl pkcs12 -nocerts -out apns-dev-key.pem -in apns-dev-key.p12 (导出私钥的pem)
    此处要求输入一个密码,输入123456.
    移除密码(上面的123456)openssl rsa -in apns-dev-key.pem -out apns-dev-key.pem
    最后,你需要将键和许可文件合成为apns-dev.pem文件,此文件在连接到APNS时需要使用:
    cat apns-dev-cert.pem apns-dev-key.pem > apns-dev.pem

2.终端运行php推送信息的代码

  • 新建文件粘贴下面的代码在里面,命名文件为push.php
    代码如下
<?php  
    $deviceToken= '7431d4f6e402b180fa37d5a0fbd0c8aed7b5acc0cf60bc81e58f9d707d5c556d'; //没有空格  
    $body = array("aps" => array("alert" => 'helloHui',"badge" => 2,"sound"=>'warning.caf'));  //推送方式,包含内容和声音
    $ctx = stream_context_create();  
    //如果在Windows的服务器上,寻找pem路径会有问题,路径修改成这样的方法:  
    //$pem = dirname(__FILE__) . '/' . 'apns-dev.pem';  
    //linux 的服务器直接写pem的路径即可  
    stream_context_set_option($ctx,"ssl","local_cert","apns-dis.pem");
    $pass = "";
    stream_context_set_option($ctx, 'ssl', 'passphrase', $pass);  
    //此处有两个服务器需要选择,如果是开发测试用,选择第二名sandbox的服务器并使用Dev的pem证书,如果是正是发布,使用Product的pem并选用正式的服务器  
//    $fp = stream_socket_client("ssl://gateway.push.apple.com:2195", $err, $errstr, 60, STREAM_CLIENT_CONNECT, $ctx);  
    $fp = stream_socket_client("ssl://gateway.sandbox.push.apple.com:2195", $err, $errstr, 60, STREAM_CLIENT_CONNECT, $ctx);
    if (!$fp) {  
        echo "Failed to connect $err $errstrn";  
        return;  
    }  
    print "Connection OK\n";  
    $payload = json_encode($body);  
    $msg = chr(0) . pack("n",32) . pack("H*", str_replace(' ', '', $deviceToken)) . pack("n",strlen($payload)) . $payload;  
    echo "sending message :" . $payload ."\n";  
    fwrite($fp, $msg);  
    fclose($fp);
?>
  • 把pem(这里要把apns-dev-cert.pem 和 apns-dev-key.pem 合成一个文件 apns-dev.pem) 文件和php文件放到一个目录下
    在终端执行下面的方法
    php push.php
    在你推送功能没有问题的情况下,就可以收到你刚刚推送的消息了

这个技巧是跟小伙伴学到的,有问题多多指教

解答小伙伴们的疑问

  • 对“Private Key”做同样操作,保存为 apns-dev-key.p12 文件。
    你这个Private Key哪来的啊

这个Private key 是私钥 可以在钥匙串里找的到,我直接上截图,你们就明白了 图中的专用密钥就是的

8817588F-B26C-4376-83F5-DFA2E413DE2A.png

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

友情链接更多精彩内容