概述
前提:
准备好推送证书aps_development.cer及其p12文件aps_development.p12
开始:
假设p12文件密码是:123456
终端操作:进入到存放cer与p12文件的文件夹
1.利用aps_development.cer文件生成.pem文件
openssl x509 -in aps_development.cer -inform der -out cer.pem
2.利用aps_development.p12文件生成.pem文件:
openssl pkcs12 -nocerts -out p12.pem -in aps_development.p12
需要输入p12的密码:123456
MAC verified OK
Enter PEM pass phrase:(设置密码)654321
Verifying - Enter PEM pass phrase:(再次输入密码)654321
3.利用两个.pem文件生成另一个.pem文件
cat cer.pem p12.pem > cp.pem
4.发消息
php push.php
push.php文件要注意的地方:
1.deviceToken
2.p12.pem密码
3.cp.pem文件。代码中:stream_context_set_option($ctx, 'ssl', 'local_cert', 'cp.pem'); 名字要对应。
php文件代码:
<?php
//deviceToken
$deviceToken = 'fc766c03b0857fb08e14ecdde3bdfef80f24030cb955dd5804fe143bbc944665';
//p12.pem文件的密码
$passphrase = '654321';
//推送的消息
$message = '这是一条豪冷的消息^_^';
$ctx = stream_context_create();
stream_context_set_option($ctx, 'ssl', 'local_cert', 'cp.pem');
stream_context_set_option($ctx, 'ssl', 'passphrase', $passphrase);
// Open a connection to the APNS server
// 上架:ssl://gateway.push.apple.com:2195
// 测试:ssl://gateway.sandbox.push.apple.com:2195
$fp = stream_socket_client('ssl://gateway.sandbox.push.apple.com:2195', $err, $errstr, 60, STREAM_CLIENT_CONNECT|STREAM_CLIENT_PERSISTENT, $ctx);
if (!$fp) exit("Failed to connect: $err $errstr" . PHP_EOL);
else echo 'Connected to APNS' . PHP_EOL;
// Create the payload body
$body['aps'] = array(
'alert' => $message,
'sound' => 'default'
);
// Encode the payload as JSON
$payload = json_encode($body);
// Build the binary notification
$msg = chr(0) . pack('n', 32) . pack('H*', $deviceToken) . pack('n', strlen($payload)) . $payload;
// Send it to the server
$result = fwrite($fp, $msg, strlen($msg));
if (!$result) echo 'Message not delivered' . PHP_EOL;
else echo 'Message successfully delivered' . PHP_EOL;
// Close the connection to the server
fclose($fp);
?>
要想一步一步的学,请
参考博客:http://blog.csdn.net/showhilllee/article/details/8631734
如果执行命令后,出现错误:
Warning: stream_socket_client(): SSL operation failed with code 1. OpenSSL Error messages:
error:14090086:SSL routines:SSL3_GET_SERVER_CERTIFICATE:certificate verify failed in push.php on line 21
则需要下载证书entrust_2048_ca.cer及添加代码:
stream_context_set_option($ctx, 'ssl', 'local_cert', 'cp.pem');
stream_context_set_option($ctx,'ssl','cafile','entrust_2048_ca.cer');
stream_context_set_option($ctx, 'ssl', 'passphrase', $passphrase);
下载地址:https://www.entrust.com/get-support/ssl-certificate-support/root-certificate-downloads/
参考博客:http://blog.csdn.net/heyufei/article/details/53616961?utm_source=itdadao&utm_medium=referral
不清楚,是不是因为php版本的问题,还是因为从一台电脑上导出p12文件到另一台电脑使用,就需要加上2048那个文件。
第一台电脑,php版本(查看命令 php -v),不需要2048文件。
PHP 5.5.29 (cli) (built: Sep 9 2015 00:26:40)
Copyright (c) 1997-2015 The PHP Group
Zend Engine v2.5.0, Copyright (c) 1998-2015 Zend Technologies
另一台MAC电脑,php版本是,需要2048文件。
PHP 5.6.25 (cli) (built: Sep 19 2016 15:45:41)
Copyright (c) 1997-2016 The PHP Group
Zend Engine v2.6.0, Copyright (c) 1998-2016 Zend Technologies
最后
以上就是矮小啤酒为你收集整理的iOS 利用PHP来进行消息推送的全部内容,希望文章能够帮你解决iOS 利用PHP来进行消息推送所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
发表评论 取消回复