Apple server-side notification in C #

I am new to .net and am doing apn server side in C #. I use the code below to send messages to the apple server.

private void pushMessage() { int port = 2195; String deviceID = "4564c705 63b371aa 3811699e 1e4ac3d2 ba592b27 f2a5a613 d25cd035 xx213e54"; String hostname = "gateway.sandbox.push.apple.com"; // TEST //String hostname = "gateway.push.apple.com"; // REAL // @"cert.p12"; String certificatePath = HttpContext.Current.Server.MapPath("Certi.p12"); //X509Certificate2 clientCertificate = new X509Certificate2(certificatePath, ""); X509Certificate2 clientCertificate = new X509Certificate2(System.IO.File.ReadAllBytes(certificatePath), "", X509KeyStorageFlags.MachineKeySet | X509KeyStorageFlags.PersistKeySet | X509KeyStorageFlags.Exportable); X509Certificate2Collection certificatesCollection = new X509Certificate2Collection(clientCertificate); TcpClient client = new TcpClient(hostname, port); // _apnsStream = new SslStream(_apnsClient.GetStream(), false, validateServerCertificate, SelectLocalCertificate); //SslStream sslStream = new SslStream(client.GetStream(), false, new RemoteCertificateValidationCallback(ValidateServerCertificate),null); SslStream sslStream = new SslStream(client.GetStream(), false, validateServerCertificate, SelectLocalCertificate); try { sslStream.AuthenticateAsClient(hostname, certificatesCollection, SslProtocols.Default, false); } catch (Exception e) { throw (e); client.Close(); return; } MemoryStream memoryStream = new MemoryStream(); BinaryWriter writer = new BinaryWriter(memoryStream); writer.Write((byte)0); //The command writer.Write((byte)0); //The first byte of the deviceId length (big-endian first byte) writer.Write((byte)32); //The deviceId length (big-endian second byte) writer.Write(HexStringToByteArray(deviceID.ToUpper())); String payload = "{\"aps\":{\"alert\":\"hello\",\"badge\":0,\"sound\":\"default\"}}"; writer.Write((byte)0); writer.Write((byte)payload.Length); byte[] b1 = System.Text.Encoding.UTF8.GetBytes(payload); writer.Write(b1); writer.Flush(); byte[] array = memoryStream.ToArray(); sslStream.Write(array); sslStream.Flush(); client.Close(); } private string HexStringToByteArray(string p) { throw new NotImplementedException(); } 

When executing, receiving an error, for example: "Failed to make SSPI call, see internal exception."

enter image description here

enter image description here

I am doing something wrong or missed here. Any certificate installation required in windows? Please help me.

+7
source share
3 answers

I changed my code in the PushNotification.class file

 _certificate = string.IsNullOrEmpty(p12FilePassword)? new X509Certificate2(File.ReadAllBytes(p12File)): new X509Certificate2(File.ReadAllBytes(p12File), p12FilePassword); 

with

 _certificate = string.IsNullOrEmpty(p12FilePassword) ? new X509Certificate2(File.ReadAllBytes(p12File)) : new X509Certificate2(File.ReadAllBytes(p12File), p12FilePassword, X509KeyStorageFlags.MachineKeySet); 
+2
source

I think this library can help you - https://github.com/Redth/PushSharp/

0
source

so try ....

 SslStream sslStream = new SslStream(client.GetStream(), false, new RemoteCertificateValidationCallback(ValidateServerCertificate), null); .... public static bool ValidateServerCertificate(object sender, X509Certificate certificate, X509Chain chain, SslPolicyErrors sslPolicyErrors) { if (sslPolicyErrors == SslPolicyErrors.None) return true; gerarLog("Certificate error: " + sslPolicyErrors); // Do not allow this client to communicate with unauthenticated servers. return false; } public static byte[] HexStringToByteArray(string hexString) { byte[] HexAsBytes = new byte[hexString.Length / 2]; for (int index = 0; index < HexAsBytes.Length; index++) { string byteValue = hexString.Substring(index * 2, 2); HexAsBytes[index] = byte.Parse(byteValue, NumberStyles.HexNumber, CultureInfo.InvariantCulture); } return HexAsBytes; } 
-2
source

All Articles