我試圖向Android設備發送推送通知,但在以下情況下出現錯誤。使用GCM時發生IOException
String msg = "push message";
String to1 = "123456";
String from1 = "098776655";
這工作得很好:
Message message = new Message.Builder()
.collapseKey("1")
.addData("message", msg)
.addData("to1", to1)
.addData("to2", to1)
.build();
但使用以下時收到錯誤:
Message message = new Message.Builder()
.collapseKey("1")
.addData("message", msg)
.addData("to", to1)
.addData("from", from1)
.build();
我甚至代替from1
使用的其他變量爲好,但仍然得到錯誤:
java.io.IOException: Server returned HTTP response code: 400 for URL: https://android.googleapis.com/gcm/send
堆棧跟蹤:
java.io.IOException: Server returned HTTP response code: 400 for URL: https://android.googleapis.com/gcm/send
[run] at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
[run] at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:39)
[run] at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:27)
[run] at java.lang.reflect.Constructor.newInstance(Constructor.java:513)
[run] at sun.net.www.protocol.http.HttpURLConnection$6.run(HttpURLConnection.java:1298)
[run] at java.security.AccessController.doPrivileged(Native Method)
[run] at sun.net.www.protocol.http.HttpURLConnection.getChainedException(HttpURLConnection.java:1292)
[run] at sun.net.www.protocol.http.HttpURLConnection.getInputStream(HttpURLConnection.java:948)
[run] at sun.net.www.protocol.https.HttpsURLConnectionImpl.getInputStream(HttpsURLConnectionImpl.java:234)
[run] at com.google.android.gcm.server.Sender.sendNoRetry(Sender.java:363)
[run] at com.google.android.gcm.server.Sender.send(Sender.java:261)
[run] at example.HelloServlet.sendToSingleDevice(HelloServlet.java:173)
[run] at example.HelloServlet.doGet(HelloServlet.java:36)
[run] at javax.servlet.http.HttpServlet.service(HttpServlet.java:617)
[run] at javax.servlet.http.HttpServlet.service(HttpServlet.java:717)
[run] at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
[run] at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
[run] at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
[run] at java.lang.reflect.Method.invoke(Method.java:597)
[run] at org.apache.catalina.security.SecurityUtil$1.run(SecurityUtil.java:270)
[run] at org.apache.catalina.security.SecurityUtil$1.run(SecurityUtil.java:269)
[run] at java.security.AccessController.doPrivileged(Native Method)
[run] at javax.security.auth.Subject.doAsPrivileged(Subject.java:517)
[run] at org.apache.catalina.security.SecurityUtil.execute(SecurityUtil.java:302)
[run] at org.apache.catalina.security.SecurityUtil.doAsPrivilege(SecurityUtil.java:163)
[run] at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:283)
[run] at org.apache.catalina.core.ApplicationFilterChain.access$000(ApplicationFilterChain.java:56)
[run] at org.apache.catalina.core.ApplicationFilterChain$1.run(ApplicationFilterChain.java:189)
[run] at java.security.AccessController.doPrivileged(Native Method)
[run] at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:185)
[run] at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:233)
[run] at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:191)
[run] at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:127)
[run] at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:102)
[run] at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)
[run] at net.stax.appserver.webapp.RequestMonitorValve.invoke(RequestMonitorValve.java:35)
[run] at net.stax.appserver.webapp.RequestSetupValve.invoke(RequestSetupValve.java:31)
[run] at org.apache.catalina.valves.RemoteIpValve.invoke(RemoteIpValve.java:647)
[run] at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:293)
[run] at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:859)
[run] at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:602)
[run] at org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:489)
[run] at java.lang.Thread.run(Thread.java:619)
[run] Caused by: java.io.IOException: Server returned HTTP response code: 400 for URL: https://android.googleapis.com/gcm/send
[run] at sun.net.www.protocol.http.HttpURLConnection.getInputStream(HttpURLConnection.java:1245)
[run] at java.net.HttpURLConnection.getResponseCode(HttpURLConnection.java:373)
[run] at sun.net.www.protocol.https.HttpsURLConnectionImpl.getResponseCode(HttpsURLConnectionImpl.java:318)
[run] at com.google.android.gcm.server.Sender.sendNoRetry(Sender.java:362)
[run] ... 33 more
[run] Exception Message : Server returned HTTP response code: 400 for URL: https://android.googleapis.com/gcm/send
爲什麼你甚至會嘗試發送兩個具有相同名稱但不同值的參數? –
對不起,這只是一個輸入錯誤在這裏,我現在已經糾正... – Arsalan
根據_GCM_文檔,確切的失敗原因在響應中描述。 –