文件服务器推送功能,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

代码如下

$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 是私钥 可以在钥匙串里找的到,我直接上截图,你们就明白了 图中的专用密钥就是的

2c0e0b6f5f8d

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值