Ошибка сертификата SSL: certificate_unknown - PullRequest
2 голосов
/ 20 октября 2011

при создании провайдера push-уведомлений для разработки мы сталкиваемся с ошибкой ниже: Я хочу узнать, что не так с сертификатом, потому что я включил push-уведомление, а затем создал сертификат, но получаю ошибку certificate_unknown?

main, RECV TLSv1 ALERT:  fatal, certificate_unknown
main, called closeSocket()
main, handling exception: javax.net.ssl.SSLHandshakeException: Received fatal alert: certificate_unknown
Error pushing notification(s):
Invalid certificate chain (Received fatal alert: certificate_unknown)!  Verify that the keystore you provided was produced according to specs...
      at javapns.notification.PushNotificationManager.sendNotification(PushNotificationManager.java:359)
      at javapns.notification.PushNotificationManager.sendNotification(PushNotificationManager.java:301)
      at javapns.notification.PushNotificationManager.sendNotification(PushNotificationManager.java:258)
      at javapns.Push.payload(Push.java:122)
      at javapns.Push.alert(Push.java:36)
      at com.applicationname.pns.PushNotification.main(PushNotification.java:31)

// мой код, который я использую для push-уведомлений

/**
 * 
 */
package com.applicationname.pns;

import org.json.JSONException;

import javapns.Push;
import javapns.devices.Device;
import javapns.notification.Payload;
import javapns.notification.PushNotificationManager;
import javapns.notification.PushNotificationPayload;


public class PushNotification
{
    private static final String HOST = "gateway.sandbox.push.apple.com";
    private static final int PORT = 2195;
    private static final int BADGE = 66;
    private static String iPhoneId = "5696ee2fa44c61fd21a7987d2b1bcf57faa1603e63cb57ff204b158fb90d28a3";
    private static String certificate = "D:/./trunk/Development/JavaPNS/src/com/applicationname/pns/privateKey.p12";
    private static String passwd = "password@1234";

    /**
     * @param args
     */
    public static void main(String[] args)
    {
        Push.alert("Hello World!", certificate, passwd, false,iPhoneId);

        PushNotificationPayload payLoad = new PushNotificationPayload();

        try
        {
            payLoad.addAlert("Hello World!");
            payLoad.addBadge(10);
        }
        catch (JSONException e)
        {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }

    }


}

Ответы [ 3 ]

2 голосов
/ 10 ноября 2011

Попробуйте загрузить открытый ключ вместо privatekey

private static String certificate = "D:/./trunk/Development/JavaPNS/src/com/applicationname/pns/privateKey.p12";

Закрытый ключ загружается через сокет SSL на стороне сервера.

1 голос
/ 10 декабря 2011

Обязательно выполните процедуру для подготовки сертификатов, документированных на официальном веб-сайте JavaPNS.Разработчики, которые следуют этой процедуре, получают положительные результаты.

0 голосов
/ 18 января 2014

Я решил эту проблему в jdk 1.7 и с помощью p12, сразу после изменения длины passwd файла p12, большего или равного 6. В противном случае возникает следующая ошибка: [[1] не передается токену 595d8..725bf javapns.communication.exceptions.InvalidCertificateChainException: недопустимая цепочка сертификатов (получено фатальное предупреждение: certificate_unknown)! Убедитесь, что предоставленное вами хранилище ключей соответствует спецификациям ...]

...