托管后推送通知不会转到iOS设备? [英] Push notification not going to iOS device after hosting?

查看:55
本文介绍了托管后推送通知不会转到iOS设备?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我想发送推送通知以使用WCF服务发送ios设备。

当我从本地计算机运行服务时,推送通知将发送到服务器

但当它在iis上托管时,通知不会发送。



i我收到以下错误:



error : -

I want to send the Push notification to send ios device using WCF service.
When i run the service from Local Machine the push notification is send to the server
but when it is hosted on iis notification is not send.

i am receiving following error:

error:-

A call to SSPI failed, see inner exception





内部异常:



inner exception:

System.ComponentModel.Win32Exception " +
    "(0x80004005): The message received was unexpected or badly formatted





什么我试过了:





What I have tried:

public string PushNotificationIOS(string deviceID)
        {
            string devicetocken=string.Empty;//  iphone device token

            try
            {

                //devicetocken = "";//  iphone device token
                devicetocken = deviceID;//  iphone device token
                int port = 2195;
                String hostname = "gateway.sandbox.push.apple.com";
                //String hostname = "gateway.push.apple.com";

                string certificatePath = System.Web.Hosting.HostingEnvironment.MapPath("~/Certificate/Certificates.pem");
                //Server.MapPath("final.p12");

                string certificatePassword = "Sudesi@123";// "mohs123$";

                X509Certificate2 clientCertificate = new X509Certificate2(certificatePath, certificatePassword, X509KeyStorageFlags.MachineKeySet);
                X509Certificate2Collection certificatesCollection = new X509Certificate2Collection(clientCertificate);

                TcpClient client = new TcpClient(hostname, port);
                SslStream sslStream = new SslStream(
                                client.GetStream(),
                                false,
                                new RemoteCertificateValidationCallback(ValidateServerCertificate),
                                null
                );


                sslStream.AuthenticateAsClient(hostname, certificatesCollection, SslProtocols.Tls, false);



                //// Encode a test message into a byte array.
                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)

                byte[] b0 = HexString2Bytes(devicetocken);
               // WriteMultiLineByteArray(b0);

                writer.Write(b0);
                String payload;
                string strmsgbody = "";
                int totunreadmsg = 20;
                strmsgbody = "Your call for complaint no. M00011 has been registered in our system. - Your ticket no for your communication is 100000000065";

                //Debug.WriteLine("during testing via device!");
                //Request.SaveAs(Server.MapPath("APNSduringdevice.txt"), true);

                payload = "{\"aps\":{\"alert\":\"" + strmsgbody + "\",\"badge\":" + totunreadmsg.ToString() + ",\"sound\":\"mailsent.wav\"},\"acme1\":\"bar\",\"acme2\":42}";

                writer.Write((byte)0); //First byte of payload length; (big-endian first byte)
                writer.Write((byte)payload.Length);     //payload length (big-endian second byte)

                byte[] b1 = System.Text.Encoding.UTF8.GetBytes(payload);
                writer.Write(b1);
                writer.Flush();

                byte[] array = memoryStream.ToArray();
                //Debug.WriteLine("This is being sent...\n\n");
                //Debug.WriteLine(array);

                sslStream.Write(array);
                sslStream.Flush();


                //Debug.WriteLine("Write failed buddy!!");
                //Request.SaveAs(Server.MapPath("Writefailed.txt"), true);


                client.Close();
                //Debug.WriteLine("Client closed.");
                //Request.SaveAs(Server.MapPath("APNSSuccess.txt"), true);

                return "True";
            }
            catch (AuthenticationException ex)
            {
                //Console.WriteLine("Authentication failed");
                //client.Close();
                //Request.SaveAs(Server.MapPath("Authenticationfailed.txt"), true);
                return ex.Message;
            }
            catch (Exception ex)
            {
                return ex.Message;
            }
        }

推荐答案

;

X509Certificate2 clientCertificate = new X509Certificate2( certificatePath,certificatePassword,X509KeyStorageFlags.MachineKeySet);
X509Certificate2Collection certificatesCollection = new X509Certificate2Collection(clientCertificate);

TcpClient client = new TcpClient(hostname,port);
SslStream sslStream = new SslStream (
client.GetStream(),
false,
new RemoteCertificateValidationCallback(ValidateServerCertificate),
null
);


sslStream.AuthenticateAsClient(hostname,certificatesCollection,SslProtocols.Tls,false);



////将测试消息编码为字节数组。
MemoryStream memoryStream = new MemoryStream();
BinaryWriter writer = new BinaryWriter(memoryStream);

writer.Write((byte)0); //命令
writer.Write((byte)0); // deviceId长度的第一个字节(big-endian第一个字节)
writer.Write((byte)32); // deviceId length(big-endian second byte)

byte [] b0 = HexString2Bytes(devicetocken);
// WriteMultiLineByteArray(b0);

writer.Write(b0);
字符串有效负载;
string strmsgbody =;
int totunreadmsg = 20;
strmsgbody =您的投诉号码M00011已在我们的系统中注册。 - 您的通信票号为100000000065;

//Debug.WriteLine(通过设备进行测试!);
//Request.SaveAs(Server.MapPath(\"APNSduringdevice.txt),true);

payload ={\aps \:{\alert \:\+ strmsgbody +\,\badge \: + totunreadmsg.ToString()+,\sound \:\mailsent.wav \},\acme1 \:\bar \,\acme2 \ :42};

writer.Write((byte)0); //有效载荷长度的第一个字节; (big-endian第一个字节)
writer.Write((byte)payload.Length); //有效负载长度(big-endian第二字节)

byte [] b1 = System.Text.Encoding.UTF8.GetBytes(payload);
writer.Write(b1);
writer.Flush();

byte [] array = memoryStream.ToArray();
//Debug.WriteLine(这是发送...... \ n \\ n);
//Debug.WriteLine(array);

sslStream.Write(array);
sslStream.Flush();


//Debug.WriteLine(\"Write failed buddy !!);
//Request.SaveAs(Server.MapPath(\"Writefailed.txt),true);


client.Close();
//Debug.WriteLine(Client closed。);
//Request.SaveAs(Server.MapPath(\"APNSSuccess.txt),true);

返回True;
}
catch(AuthenticationException ex)
{
//Console.WriteLine(身份验证失败);
//client.Close();
//Request.SaveAs(Server.MapPath(\"Authenticationfailed.txt),true);
返回ex.Message;
}
catch(exception ex)
{
return ex.Message;
}
}
"; X509Certificate2 clientCertificate = new X509Certificate2(certificatePath, certificatePassword, X509KeyStorageFlags.MachineKeySet); X509Certificate2Collection certificatesCollection = new X509Certificate2Collection(clientCertificate); TcpClient client = new TcpClient(hostname, port); SslStream sslStream = new SslStream( client.GetStream(), false, new RemoteCertificateValidationCallback(ValidateServerCertificate), null ); sslStream.AuthenticateAsClient(hostname, certificatesCollection, SslProtocols.Tls, false); //// Encode a test message into a byte array. 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) byte[] b0 = HexString2Bytes(devicetocken); // WriteMultiLineByteArray(b0); writer.Write(b0); String payload; string strmsgbody = ""; int totunreadmsg = 20; strmsgbody = "Your call for complaint no. M00011 has been registered in our system. - Your ticket no for your communication is 100000000065"; //Debug.WriteLine("during testing via device!"); //Request.SaveAs(Server.MapPath("APNSduringdevice.txt"), true); payload = "{\"aps\":{\"alert\":\"" + strmsgbody + "\",\"badge\":" + totunreadmsg.ToString() + ",\"sound\":\"mailsent.wav\"},\"acme1\":\"bar\",\"acme2\":42}"; writer.Write((byte)0); //First byte of payload length; (big-endian first byte) writer.Write((byte)payload.Length); //payload length (big-endian second byte) byte[] b1 = System.Text.Encoding.UTF8.GetBytes(payload); writer.Write(b1); writer.Flush(); byte[] array = memoryStream.ToArray(); //Debug.WriteLine("This is being sent...\n\n"); //Debug.WriteLine(array); sslStream.Write(array); sslStream.Flush(); //Debug.WriteLine("Write failed buddy!!"); //Request.SaveAs(Server.MapPath("Writefailed.txt"), true); client.Close(); //Debug.WriteLine("Client closed."); //Request.SaveAs(Server.MapPath("APNSSuccess.txt"), true); return "True"; } catch (AuthenticationException ex) { //Console.WriteLine("Authentication failed"); //client.Close(); //Request.SaveAs(Server.MapPath("Authenticationfailed.txt"), true); return ex.Message; } catch (Exception ex) { return ex.Message; } }


这篇关于托管后推送通知不会转到iOS设备?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆