stream_socket_client (): невозможно подключиться к ssl: //gateway.sandbox.push.apple.com: 2195 (соединение отклонено)

Я сделал php-файл для отправки уведомлений пользователям Apple iphone. Это работает для другого сервера, но не работает на моем сервере. Я сделал файл .pem точно, а также открыл номер порта 2195,2196. Но все равно его не работает.
Пожалуйста, кто-нибудь, помогите мне избавиться от этой проблемы. Вот мой php-код для отправки push-уведомлений:

 <?php
// Put your device token here (without spaces):
$deviceToken = 'f672c26cbfb279e45c1b66d0ddb738d8043c785d5bb8dd20a72d52ae88d4a604';
// Put your private key's passphrase here:
$passphrase = 'pushchat';
// Put your alert message here:
$message = 'Welcome in testing';
$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 'Message successfully delivered' . PHP_EOL;
// Close the connection to the server
fclose($fp);
?>

3

Решение

Я нашел эту статью, но у меня были те же проблемы, и моя проблема была на самом деле двумя, и я подумал, что она может быть полезна здесь. Я на Ubuntu / Php 5.5

Проверьте свои сертификаты!

prompt\#: openssl s_client -connect gateway.sandbox.push.apple.com:2195
-cert ./push-crt.pem
-key ./push-key.pem
-CApath ./entrust_root_certification_authority.pem

Когда я нашел вышеупомянутый тест, я понял, что на моем сервере отсутствует сертификат корневого администратора, пункт 1. Как только я запустил вышеописанное, и он заработал, я понял, что используемая библиотека пропустила только один файл, подробнее об этом во втором пункте.

1. Корневой сертификат

На моем сервере не был установлен правильный корневой сертификат и, следовательно, я не смог проверить мой файл PEM. Я вернусь к этому дальше. Как только я нашел эту страницу [Где взять файл PEM Entrust Root CA?] [1] Я проверил, и у меня та же проблема. Я предполагаю, что вы д / л в вашей домашней папке …

prompt\#: sudo cp ~/entrust_root_certification_authority.pem
/usr/local/share/ca-certificates/entrust_root_certification_authority.crt
prompt\#: sudo update-ca-certificates

Вы должны увидеть ответ, указывающий, что сертификат был установлен или обновлен. Теперь я куда-то добирался. Я начал получать другую ошибку соединения, непосредственно связанную с моим файлом PEM. Что-то, с чем я мог работать.

2. Ваш файл PEM

Если вы используете библиотеку, подобную моей, которая проходит один файл, и вы прошли вышеупомянутый тест, используя и свой сертификат, и ключ, то вам нужно объединить свой ключ и сертификат. Для меня, используя мои примеры имен выше из push-crt.pem

prompt\#: cat push-crt.pem > push.pem
prompt\#: echo >> push.pem
prompt\#: cat push-key.pem >> push.pem

затем я использовал комбинированную пару ключ / сертификат, и все начало работать.

Уф. Надеюсь, это поможет кому-то.

3

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

Попробуйте этот код и убедитесь, что ваш сертификат, указанный в пути к серверу, особенно ck.pem

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

// Put your alert message here:
$message = 'Hello';

////////////////////////////////////////////////////////////////////////////////

$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 'Message successfully delivered' . PHP_EOL;

}

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

}
3

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