Javapns问题 - 卡在pushManager.sendNotification(client,aPayload)上;功能

时间:2011-07-24 03:40:04

标签: apple-push-notifications

每次我尝试发送通知

获取以下错误: 连接初始化... 尝试失败......再试一次 preclose 在最后 enter code here java.net.SocketException:Socket已关闭     at com.sun.net.ssl.internal.ssl.SSLSocketImpl.checkEOF(Unknown Source)     at com.sun.net.ssl.internal.ssl.AppInputStream.read(Unknown Source)     at sun.nio.cs.StreamDecoder.readBytes(Unknown Source)     at sun.nio.cs.StreamDecoder.implRead(Unknown Source)     at sun.nio.cs.StreamDecoder.read(Unknown Source)     在java.io.InputStreamReader.read(未知来源)     在java.io.BufferedReader.fill(未知来源)     在java.io.BufferedReader.readLine(未知来源)     在java.io.BufferedReader.readLine(未知来源)     at ts.javapns.back.PushNotificationManager.sendNotification(PushNotificationManager.java:199)     在org.apache.jsp.japnslist_jsp._jspService(org.apache.jsp.japnslist_jsp:118)     在org.apache.jasper.runtime.HttpJspBase.service(HttpJspBase.java:97)     在javax.servlet.http.HttpServlet.service(HttpServlet.java:802)     在org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:322)     在org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:291)     在org.apache.jasper.servlet.JspServlet.service(JspServlet.java:241)     在javax.servlet.http.HttpServlet.service(HttpServlet.java:802)     在org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:252)     在org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:173)     在org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:213)     在org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:178)     在org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:126)     在org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:105)     在org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:107)     在org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:148)     在org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:856)     在org.apache.coyote.http11.Http11Protocol $ Http11ConnectionHandler.processConnection(Http11Protocol.java:744)     在org.apache.tomcat.util.net.PoolTcpEndpoint.processSocket(PoolTcpEndpoint.java:527)     在org.apache.tomcat.util.net.LeaderFollowerWorkerThread.runIt(LeaderFollowerWorkerThread.java:80)     at org.apache.tomcat.util.threads.ThreadPool $ ControlRunnable.run(ThreadPool.java:684)     在java.lang.Thread.run(未知来源)

enter code here

您使用的是哪个版本的产品?什么操作系统? Windows XP,最新版本的javaapns

    // APNs Server Host & port      
    String HOST = "gateway.sandbox.push.apple.com";      
    int PORT = 2195;      
    // Badge      
    int BADGE = 6;      
    // iPhone's UDID (64-char device token)      
    String iPhoneId = "aebf53cc8d6bfaf47dace40747091fa5b0fc837b...";      

    String certificate = "C:/webapplication/WEB-INF/cert.p12";      
    String passwd = "password";  

    System.out.println( "Setting up Push notification" ); 


    //Set system properties .....
    System.setProperty("javax.net.ssl.trustStore", "/var/www/apns/<apple.keystore>"); 

    System.setProperty("javax.net.ssl.trustStorePassword", "<pass>"); 


   try {              
   // Setup up a simple message              
 PayLoad aPayload = new PayLoad();              
 aPayload.addBadge( BADGE );              
 System.out.println( "Payload setup successfull." );              
 System.out.println ( aPayload );              

 // Get PushNotification Instance              
 PushNotificationManager pushManager = PushNotificationManager.getInstance();       

 System.out.println( "Linking iPhone's UDID (64-char device token) to stringName" );  

 // Link iPhone's UDID (64-char device token) to a stringName              
 pushManager.addDevice("iPhone", iPhoneId);              
 System.out.println( "iPhone UDID taken." );              
 System.out.println("Token:"+pushManager.getDevice("iPhone").getToken());              

 // Get iPhone client              
 Device client = pushManager.getDevice( "iPhone" );              
 System.out.println( "Client setup successfull." );     


 // Initialize connection              
 pushManager.initializeConnection( HOST, PORT, certificate, passwd,   SSLConnectionHelper.KEYSTORE_TYPE_PKCS12);              
 System.out.println( "Connection initialized..." );        


 // Send message              
 pushManager.sendNotification( client, aPayload );     
 System.out.println( "Message sent!" ); 

 //Remove device
 pushManager.removeDevice(iPhoneId); 
 System.out.println( "Removing Device" );

 System.out.println("# of attempts:" + pushManager.getRetryAttempts() );              
 pushManager.stopConnection();              
 System.out.println( "done" );          
} catch (Exception e) {              
   e.printStackTrace();          
} 

据我所知,我现在在PushNotificationManager.java文件中遇到问题

功能:      public void sendNotification(设备设备,PayLoad有效负载)

在sendNotification的这一行:         this.socket.getOutputStream()。write(getMessage(device.getToken(),new PayLoad()));

套接字已关闭,但我不知道为什么会这样?

请帮忙。

2 个答案:

答案 0 :(得分:1)

JavaPNS最近更新为2.0,并修复了截至发布日期的所有报告问题。它确实解决了您所描述的问题。

西尔

答案 1 :(得分:0)

我们是否必须为Ad Hoc指定用于开发或生产服务器的沙盒服务器?