0

ウォレットのプッシュ通知の更新に悩まされています。次のコードを使用しました。サーバーが接続されていないというエラーが発生しました。

資格情報がありませんでした。助けてください。この問題を修正してください。

通帳を登録し、プッシュトークンをサーバーに返しました。

このキーは通帳生成証明書キーと同じです。

            $certifile = 'passbook/certificates/AppleWWDRCA.pem'; 
            $passphrase = 'xxxxxxxx';
            $trust ='';
            $url = 'ssl://gateway.push.apple.com:2195';
            $ctx = stream_context_create();
            stream_context_set_option($ctx, 'ssl', 'local_cert', $certifile);
            stream_context_set_option($ctx, 'ssl', 'passphrase', $passphrase);
            $fp = stream_socket_client($url, $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;
            $body['aps'] = array(
                'alert' => $message,
                'sound' => 'default',
                'pushToken'=>'xxxxxxxxxxxxxx',
                 'passTypeId'=>'xxxxxxxxx'

            );

            $payload = json_encode($body);

            $msg = chr(0) . pack('n', 32) . pack('H*', $deviceToken) . pack('n', strlen($payload)) . $payload;

            $result = fwrite($fp, $msg, strlen($msg));

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

私を助けてください。


サーバーに接続しましたが、プッシュ通知の送信でエラーが発生しました。

$body['aps'] = array( );
$msg = chr(0) . pack('n', 32) . pack('H*', $pushToken) . pack('n', strlen($payload)) . $payload;

if (!$result)
            echo 'Message not delivered' . PHP_EOL;
        else
            echo 'Message successfully delivered' . PHP_EOL;

メッセージが配信されませんでした: 10053。

ユーザーの予約時間は動的に作成され、デバイスに表示されます。

ユーザーが予約日を変更した場合、プッシュ通知を介して予約日時をユーザーパスに動的に更新する必要があります。

誰でも私の通帳を更新するのを手伝ってください。

4

1 に答える 1

0

ここでPHPコードを確認してください(最初の回答)。それは私のための仕事です。 PHP Apple Enhanced Push Notification 読み取りエラー応答

間違った証明書を使用しています。キーチェーンからエクスポートして、パス証明書 (p12) から pem ファイルを作成する必要があります。

cer ファイルから P12 と PEM ファイルを作成する方法
1. 保存フォルダーに移動します
2. ターミナルを開き、そのフォルダーに cd します
openssl x509 -inform der -in aps_development.cer -out certificate.pem
openssl pkcs12 -nocerts -in Certiticates.p12 - out p12Certificates.pem
[.p12 のパスワードと .pem のパスワードを入力]
cat certificate.pem p12Certificates.pem > apns_cert.pem

于 2016-01-14T20:13:24.303 に答える