use*_*472 4 php push-notification ios
我是一个新的PHP并在codeigniter中编写推送通知的代码,但我得到了这些错误.
这是我的模特..
function sendmessage($appid, $deviceid, $status, $message)
{
$deviceToken = '0f744707bebcf74f9b7c25d48e3358945f6aa01da5ddb387462c7eaf61bbad78';
$message = 'My first push notification!';
$ctx = stream_context_create();
stream_context_set_option($ctx, 'ssl', 'local_cert', 'ck.pem');
//stream_context_set_option($ctx, 'ssl', 'passphrase', 'essar@123');
$fp = stream_socket_client('ssl://gateway.sandbox.push.apple.com:2195', $err, $errstr, 60, STREAM_CLIENT_CONNECT, $ctx);
if (!$fp){
exit("Failed to connect: $err $errstr" . PHP_EOL);
}
else {
print "Connection OK/n";
}
echo 'Connected to APNS' . PHP_EOL;
$body['aps'] = array(
'alert' => $message,
'sound' => 'default'
);
$payload = json_encode($body);
$msg = chr(0) . pack('n', 32) . pack('H*', $deviceToken) . pack('n', strlen($payload)) . $payload;
$result = fwrite($fp, $msg, strlen($msg));
if (!$result)
echo 'Message not delivered' . PHP_EOL;
else
echo 'Message successfully delivered' . PHP_EOL;
fclose($fp);
$data = array(
'message' => $this->message . 'add',
'appid' => $this->appid,
'deviceid' => $this->deviceid,
'status' => $status
);
$this->sendmessage($data);
Run Code Online (Sandbox Code Playgroud)
错误信息:
消息:stream_socket_client():SSL操作失败,代码为1. OpenSSL错误消息:错误:14094410:SSL例程:SSL3_READ_BYTES:sslv3警报握手失败消息:stream_socket_client():无法启用加密消息:stream_socket_client():无法连接到ssl://gateway.sandbox.push.apple.com:2195(未知错误)
为开发和分发创建临时证书和推送通知后.按照生成推送通知的步骤操作
要使用您生成的证书,您需要创建一个PEM文件,用于存储Apple推送通知服务SSL证书和私钥.您可以从终端创建PEM文件.
导航到包含先前生成的证书和密钥的目录,然后执行以下步骤.此处的文件名反映了作为本课程一部分生成的证书的名称.您必须根据您提供的证书名称更新语法.
首先创建应用程序证书PEM文件.您可以通过双击aps_developer_identity.cer证书文件,然后打开Keychain Assistant并将证书导出为ap12文件,然后将其转换为PEM文件,方式与PushNotificationApp.p12转换为PEM的方式相同文件.或者,您可以使用单个命令行将aps_developer_identity.cer证书文件直接转换为PEM文件.这里我们选择单命令行选项,如下所示:
openssl x509 -inform der -outform pem -in aps_developer_identity.cer -out PushNotificationAppCertificate.pem
Run Code Online (Sandbox Code Playgroud)
现在创建应用程序密钥PEM文件,如下所示.您需要输入导入密码和PEM密码短语:
openssl pkcs12 -in PushNotificationApp.p12 -out PushNotificationAppKey.pem -nocerts
Run Code Online (Sandbox Code Playgroud)
输入导入密码:MAC已验证确定输入PEM密码短语:验证 - 输入PEM密码短语:
现在连接两个文件:
cat PushNotificationAppCertificate.pem PushNotificationAppKey.pem > PushNotificationAppCertificateKey.pem
Run Code Online (Sandbox Code Playgroud)
打开Mac终端并从包含您生成的证书的目录中执行以下行:
openssl s_client -connect gateway.sandbox.push.apple.com:2195 -cert PushNotificationAppCertificate.pem -key PushNotificationAppKey.pem
Run Code Online (Sandbox Code Playgroud)
然后,系统会要求您输入您提交的密钥的密码:
Enter pass phrase for PushNotificationAppKey.pem:
Run Code Online (Sandbox Code Playgroud)
如果一切正常,那么服务器应该向您发送大量可能如下所示的信息:
CONNECTED(00000003)
depth=1 /C=US/O=Entrust, Inc./OU=www.entrust.net/rpa is incorporated by reference/OU=(c) 2009 Entrust, Inc./CN=Entrust Certification Authority - L1C
verify error:num=20:unable to get local issuer certificate verify return:0
...
Key-Arg : None
Start Time: 1326899631 Timeout : 300 (sec) Verify return code: 0 (ok)
At the end of this, you can enter some text and then select the return key. We entered the text "**Hello World**".
**Hello World
closed**
Run Code Online (Sandbox Code Playgroud)
这样就完成了与服务器的通信,并验证了我们的证书是否有效.