每次我尝试发送通知
获取以下错误:
连接初始化...
尝试失败......再试一次
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()));
套接字已关闭,但我不知道为什么会这样?
请帮忙。
答案 0 :(得分:1)
JavaPNS最近更新为2.0,并修复了截至发布日期的所有报告问题。它确实解决了您所描述的问题。
西尔
答案 1 :(得分:0)
我们是否必须为Ad Hoc指定用于开发或生产服务器的沙盒服务器?