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

На самом деле я новичок в 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

person Ashif Shereef    schedule 01.10.2015    source источник


Ответы (2)


У меня была точно такая же проблема, используя тот же пример кода - отлично работает для 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 сентября. Теперь он перестал работать, поэтому я думаю, что это снова сертификаты, но, по крайней мере, это может помочь вам с вашим решением.

person MDP77    schedule 02.10.2015
comment
Не могли бы вы пояснить? Я много раз работал с SSL. Но это не обычный SSL, верно? Итак, можете ли вы провести меня через серверную часть следующего? Установка этого SSL на сервер (детали пути и все) И следующие две строки? stream_context_set_option($ctx, 'ssl', 'local_cert', 'ck.pem'); stream_context_set_option($ctx, 'ssl', 'парольная фраза', $парольная фраза); Каким соглашениям об именах следует следовать в моем коде, чтобы назвать файл ck.pem? Могу ли я переименовать файл PEM во что-нибудь? - person Ashif Shereef; 03.10.2015

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

person Ashif Shereef    schedule 05.10.2015