Android 到服务器上的 Appengine RPC Nullponter

Posted

技术标签:

【中文标题】Android 到服务器上的 Appengine RPC Nullponter【英文标题】:Android to Appengine RPC Nullponter on server 【发布时间】:2011-08-31 18:27:26 【问题描述】:

我有一个 Appengine 连接的 Andorid 项目,以启用服务器和 android 设备之间的 RPC 调用。当我在 GWT 客户端上调用时,一切正常,但是当我从 Android 应用程序调用时,服务器会抛出这个空指针异常。我正在使用 Requestfactory 进行 RPC 调用。 GAE 1.5.2 版

[ERROR] Unexpected error
java.lang.NullPointerException
    at java.util.concurrent.ConcurrentHashMap.get(ConcurrentHashMap.java:768)
    at com.google.web.bindery.requestfactory.server.ServiceLayerCache.getOrCache(ServiceLayerCache.java:225)
    at com.google.web.bindery.requestfactory.server.ServiceLayerCache.resolveRequestFactory(ServiceLayerCache.java:198)
    at com.google.web.bindery.requestfactory.server.SimpleRequestProcessor.process(SimpleRequestProcessor.java:203)
    at com.google.web.bindery.requestfactory.server.SimpleRequestProcessor.process(SimpleRequestProcessor.java:127)
    at com.google.web.bindery.requestfactory.server.RequestFactoryServlet.doPost(RequestFactoryServlet.java:133)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:637)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:717)
    at org.mortbay.jetty.servlet.ServletHolder.handle(ServletHolder.java:511)
    at org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1166)
    at com.google.appengine.tools.development.HeaderVerificationFilter.doFilter(HeaderVerificationFilter.java:35)
    at org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1157)
    at com.google.appengine.api.blobstore.dev.ServeBlobFilter.doFilter(ServeBlobFilter.java:58)
    at org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1157)
    at com.google.apphosting.utils.servlet.TransactionCleanupFilter.doFilter(TransactionCleanupFilter.java:43)
    at org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1157)
    at com.google.appengine.tools.development.StaticFileFilter.doFilter(StaticFileFilter.java:122)
    at org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1157)
    at com.google.appengine.tools.development.BackendServersFilter.doFilter(BackendServersFilter.java:97)
    at org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1157)
    at org.mortbay.jetty.servlet.ServletHandler.handle(ServletHandler.java:388)
    at org.mortbay.jetty.security.SecurityHandler.handle(SecurityHandler.java:216)
    at org.mortbay.jetty.servlet.SessionHandler.handle(SessionHandler.java:182)
    at org.mortbay.jetty.handler.ContextHandler.handle(ContextHandler.java:765)
    at org.mortbay.jetty.webapp.WebAppContext.handle(WebAppContext.java:418)
    at com.google.apphosting.utils.jetty.DevAppEngineWebAppContext.handle(DevAppEngineWebAppContext.java:70)
    at org.mortbay.jetty.handler.HandlerWrapper.handle(HandlerWrapper.java:152)
    at com.google.appengine.tools.development.JettyContainerService$ApiProxyHandler.handle(JettyContainerService.java:351)
    at org.mortbay.jetty.handler.HandlerWrapper.handle(HandlerWrapper.java:152)
    at org.mortbay.jetty.Server.handle(Server.java:326)
    at org.mortbay.jetty.HttpConnection.handleRequest(HttpConnection.java:542)
    at org.mortbay.jetty.HttpConnection$RequestHandler.content(HttpConnection.java:938)
    at org.mortbay.jetty.HttpParser.parseNext(HttpParser.java:755)
    at org.mortbay.jetty.HttpParser.parseAvailable(HttpParser.java:212)
    at org.mortbay.jetty.HttpConnection.handle(HttpConnection.java:404)
    at org.mortbay.io.nio.SelectChannelEndPoint.run(SelectChannelEndPoint.java:409)
    at org.mortbay.thread.QueuedThreadPool$PoolThread.run(QueuedThreadPool.java:582)

问题是堆栈跟踪没有提供有关我的代码中某些问题的任何信息。

我想要做的是将异常从 Android 客户端发送到 AppEngine 服务器。这就是android端代码。

new AsyncTask<Void, Void, Void>() 

            @Override
            protected Void doInBackground(Void... arg0) 
                MyRequestFactory factory = (MyRequestFactory) Util
                .getRequestFactory(context,
                        MyRequestFactory.class);
                ExceptionRequest request = factory.exceptionRequest();

                ExceptionProxy ep = request.create(ExceptionProxy.class);
                ep.setClassName(aThrowable.getClass().getSimpleName());
                ep.setRevision(1);
                ep.setVersionName("2.1.2");
                ep.setStack("");

                request.updateException(ep).fire();
                return null;
            

        .execute();

这会引发此异常(内部服务器错误)

09-05 22:29:36.104: ERROR/AndroidRuntime(602): Caused by: java.lang.RuntimeException: Internal Server Error
09-05 22:29:36.104: ERROR/AndroidRuntime(602):     at com.google.web.bindery.requestfactory.shared.Receiver.onFailure(Receiver.java:44)
09-05 22:29:36.104: ERROR/AndroidRuntime(602):     at com.google.web.bindery.requestfactory.shared.impl.AbstractRequestContext.fail(AbstractRequestContext.java:677)
09-05 22:29:36.104: ERROR/AndroidRuntime(602):     ... 13 more

在 Web 客户端上执行 RPC 效果很好,但在 Android 上我无法让它工作。

【问题讨论】:

由于您根本没有告诉我们有关您的应用程序或您如何称呼它的任何信息,我看不出任何人可能会找出问题所在。 用更多信息更新了问题 【参考方案1】:

我遇到了这个并且偶然(我认为)找到了答案。创建一个新的 AppEngine 应用程序(不是一个新的 App Engine Connected Android 项目,而是直接访问 appengine.google.com),并尝试在您新创建的应用程序上对其进行测试。我认为他们对 AppEngine 进行了一些更改,您需要一个新的才能正确使用 App Engine Connected Android Project。

祝你好运!

【讨论】:

【参考方案2】:

这是因为 GAE 的版本。更新到 1.6.1。

【讨论】:

这个问题有点老了,我已经解决了。我只是忘了在这里写一个答案。是的,我做了一个更新,从那时起它就起作用了。【参考方案3】:

为了让安卓应用与谷歌应用引擎一起工作,你必须在 Eclipse 中创建与 App Engine 连接的安卓项目,并默认配置 GWT 2.3.0:

Windows -&gt; Preferences -&gt; Google -&gt; Web Toolkit(而不是 2.4.0rc1)

如果您在创建项目后尝试将 GWT 版本从 2.4.0rc1 更改为 2.3.0,Android 应用程序将始终出现此错误(Web 应用程序可以运行)。

【讨论】:

以上是关于Android 到服务器上的 Appengine RPC Nullponter的主要内容,如果未能解决你的问题,请参考以下文章

Firebase 身份验证不适用于 AppEngine 上的 Ktor 应用程序

在 1 个请求中将多个文件从 Android 上传到 AppEngine

AppEngine 开发服务器上的 Google KMS - 日志混乱

为 Web 和 Android 服务的 AppEngine GWT-RPC 服务

使用 Google AppEngine 创建 Java Web 服务

Android 推送通知 - Google Play