使用GCM时出现IOException

时间:2012-12-20 04:53:59

标签: android google-cloud-messaging

我正在尝试向Android设备发送推送通知,但在以下情况下收到错误。

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

3 个答案:

答案 0 :(得分:0)

这可能是您没有访问该URL的权限,或者您需要安装新证书,服务器提供的证书,您需要与服务器端联系联系!

答案 1 :(得分:0)

谢谢,每个人都修好了......

问题不在于我只是改变

.addData("from", from1)

.addData("from1", from1)

它有效......

可能是from是GCM服务器端的关键字...

答案 2 :(得分:0)

如果你查看从服务器(响应主体)得到的响应,它会告诉你from确实是一个保留字(因为它在Intent中用于Android,据我记得。)