Push-уведомление Apple получает сообщение об ошибке Аутентификация не удалась, поскольку удаленная сторона закрыла транспортный поток

Я получаю следующую ошибку "Аутентификация не удалась, поскольку удаленная сторона закрыла транспортный поток"

после кода ling: stream.AuthenticateAsClient(this.appleSettings.Host, this.certificates, System.Security.Authentication.SslProtocols.Ssl3, false);

Это указывало на действительный стр. 12

void connect()
        {
            client = new TcpClient();

            //Notify we are connecting
            var eoc = this.OnConnecting;
            if (eoc != null)
                eoc(this.appleSettings.Host, this.appleSettings.Port);

            try
            {
                client.Connect(this.appleSettings.Host, this.appleSettings.Port);
            }
            catch (Exception ex)
            {
                throw new ConnectionFailureException("Connection to Host Failed", ex);
            }

            if (appleSettings.SkipSsl)
            {
                networkStream = client.GetStream();
            }
            else
            {
                stream = new SslStream(client.GetStream(), false,
                    new RemoteCertificateValidationCallback((sender, cert, chain, sslPolicyErrors) => { return true; }),
                    new LocalCertificateSelectionCallback((sender, targetHost, localCerts, remoteCert, acceptableIssuers) =>
                    {
                        return certificate;
                    }));

                try
                {
                    stream.AuthenticateAsClient(this.appleSettings.Host, this.certificates, System.Security.Authentication.SslProtocols.Ssl3, false);
                    //stream.AuthenticateAsClient(this.appleSettings.Host);
                }
                catch (System.Security.Authentication.AuthenticationException ex)
                {
                    throw new ConnectionFailureException("SSL Stream Failed to Authenticate as Client", ex);
                }

                if (!stream.IsMutuallyAuthenticated)
                    throw new ConnectionFailureException("SSL Stream Failed to Authenticate", null);

                if (!stream.CanWrite)
                    throw new ConnectionFailureException("SSL Stream is not Writable", null);

                networkStream = stream;
            }

            //Start reading from the stream asynchronously
            Reader();
        }

    }

person Ortal Blumenfeld Lagziel    schedule 03.11.2014    source источник
comment
есть такая же проблема. любая подсказка?   -  person Diogo    schedule 20.11.2014
comment
Какой сертификат вы использовали? Я пытаюсь сделать то же самое здесь, но я не уверен, что у меня есть правильный сертификат   -  person Nick Prozee    schedule 27.08.2015


Ответы (2)


stream.AuthenticateAsClient(this.appleSettings.Host, this.certificates, System.Security.Authentication.SslProtocols.Ssl3, false);

https://developer.apple.com/news/?id=10222014a

Push-серверы Apple больше не поддерживают SSL3. Попробуйте изменить это на .Default или .TLS, и это должно сработать.

person KristofferArl    schedule 02.12.2014

Я использовал Moon API для .NET и изменил протокол Ssl3 на Tls, как указано выше, и использовал файл .p12 вместо .pem. P12 создается с использованием следующих сертификатов.

$ openssl pkcs12 -export -in chatPushCert.pem -inkey chatPushKey.pem -certfile CertificateSigningRequest.certSigningRequest -name "apn_developer_identity" -out apn_developer_identity.p12

и все работает очень хорошо.

person Dilip Ingole Patil    schedule 01.05.2015
comment
Я тоже загрузил Moon Api, но там я получаю: Аутентификация не удалась, потому что удаленная сторона закрыла транспортный поток. Есть идеи? Я использовал сертификат подписи кода с сервера Apple, это правильный? - person Nick Prozee; 27.08.2015
comment
Вы сгенерировали вышеуказанные сертификаты, если да, то используйте это внутри процесса разработчика .Net в качестве руководства по лунному API и измените протокол Ssl3 на Tls. - person Dilip Ingole Patil; 27.08.2015
comment
Я извлек файл p12 из цепочки для ключей на сервере Apple вместо использования openssl. - person Nick Prozee; 27.08.2015
comment
Это действительно работает. Несколько голосов за вашу помощь, спасибо. Последний вопрос, есть ли у вас какая-либо информация о настройке токена устройства? С Уважением - person Nick Prozee; 27.08.2015
comment
на самом деле вы не можете определить какой-либо токен для своего устройства, сервер Apple назначит токен устройства вашему устройству, для чего вы должны поместить следующий код в свой файл AppDelegate.m. - person Dilip Ingole Patil; 31.08.2015
comment
- (void)application:(UIApplication*)application didRegisterForRemoteNotificationsWithDeviceToken:(NSData*)deviceToken { NSLog(@My token is: %@, deviceToken); NSString *token=[[NSUserDefaults standardUserDefaults] objectForKey:@devicetoken]; } - person Dilip Ingole Patil; 31.08.2015
comment
вызов этой функции, если вы успешно отказались от push-уведомления, и вы получите токен своего устройства. - person Dilip Ingole Patil; 31.08.2015