APNS push-уведомления не отправляются

На самом деле я новичок в APNS и пользуюсь некоторой помощью онлайн-форумов и блогов. Я использую PHP для реализации на стороне сервера. Вот мой PHP-код

<?php

// Put your device token here (without spaces):
$deviceToken = '0f744707bebcf74f9b7c25d48e3358945f6aa01da5ddb387462c7eaf61bbad78';

// Put your private key's passphrase here:
$passphrase = 'pushchat';

// Put your alert message here:
$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', $passphrase);

// Open a connection to the APNS server
$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);

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 '

‘. PHP_EOL;

// Close the connection to the server
fclose($fp);

Я преобразовал файл .p12 в файл PEM, назвал его ck.pem и разместил в том же месте, где находится файл php. Когда я выполняю файл PHP, выводится следующее. Есть что-то, чего мне не хватает. Я сомневаюсь в части сертификата.

Connected to APNS
Message successfully delivered

0

Решение

У меня была точно такая же проблема, с использованием точно такого же примера кода — прекрасно работает для Android, но не работает на IOS без возврата ошибки.

Чтобы исправить мою проблему, мне пришлось снова создать сертификат SSL для приложения, а затем запустить

openssl x509 -in aps_development.cer -inform der -out  aps_development.pem

openssl pkcs12 -nocerts -out  aps_developmentKey.pem -in ios_development.p12

cat aps_development.pem aps_developmentKey.pem > ck.pem

Окончательно проверено на:
openssl s_client -connect gateway.sandbox.push.apple.com:2195 -cert aps_development.pem -key aps_developmentKey.pem -CAfile entrust_2048_ca.cer

После этого все работало отлично, это было 29 сентября — теперь оно перестало работать, поэтому я думаю, что это снова сертификаты, но, по крайней мере, это может помочь вам с вашим решением.

1

Другие решения

Я на самом деле заменил UDID устройства на токен устройства, и он работает как шарм. Вы не можете использовать UDID больше.

0

По вопросам рекламы [email protected]