如何在GWT中解决IncompatibleRemoteServiceException?

时间:2013-05-02 09:02:03

标签: gwt

我已经通过Eclipse插件创建了一个新的GWT项目 - 并且只是试图调用这个服务器端函数。我删除了使用生成的代码创建的初始“greet”函数 - 并将其替换为另一个函数“QueryResponse search(QueryRequest query)。但是当客户端调用函数时我收到此错误。在我看来虽然生成的示例“greet”函数是从GWT SDK内部的某个地方调用的。帮助!

Starting Jetty on port 8888
[WARN] greetServlet: An IncompatibleRemoteServiceException was thrown while processing this call.
com.google.gwt.user.client.rpc.IncompatibleRemoteServiceException: This application is out of date, please click the refresh button on your browser. ( Could not locate requested method 'greetServer(com.myproject.shared.QueryRequest)' in interface 'com.myproject.client.GreetingService' )
    at com.google.gwt.user.server.rpc.RPC.decodeRequest(RPC.java:310)
    at com.google.gwt.user.server.rpc.RemoteServiceServlet.processCall(RemoteServiceServlet.java:206)
    at com.google.gwt.user.server.rpc.RemoteServiceServlet.processPost(RemoteServiceServlet.java:248)
    at com.google.gwt.user.server.rpc.AbstractRemoteServiceServlet.doPost(AbstractRemoteServiceServlet.java:62)
    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:487)
    at org.mortbay.jetty.servlet.ServletHandler.handle(ServletHandler.java:362)
    at org.mortbay.jetty.security.SecurityHandler.handle(SecurityHandler.java:216)
    at org.mortbay.jetty.servlet.SessionHandler.handle(SessionHandler.java:181)
    at org.mortbay.jetty.handler.ContextHandler.handle(ContextHandler.java:729)
    at org.mortbay.jetty.webapp.WebAppContext.handle(WebAppContext.java:405)
    at org.mortbay.jetty.handler.HandlerWrapper.handle(HandlerWrapper.java:152)
    at org.mortbay.jetty.handler.RequestLogHandler.handle(RequestLogHandler.java:49)
    at org.mortbay.jetty.handler.HandlerWrapper.handle(HandlerWrapper.java:152)
    at org.mortbay.jetty.Server.handle(Server.java:324)
    at org.mortbay.jetty.HttpConnection.handleRequest(HttpConnection.java:505)
    at org.mortbay.jetty.HttpConnection$RequestHandler.content(HttpConnection.java:843)
    at org.mortbay.jetty.HttpParser.parseNext(HttpParser.java:647)
    at org.mortbay.jetty.HttpParser.parseAvailable(HttpParser.java:211)
    at org.mortbay.jetty.HttpConnection.handle(HttpConnection.java:380)
    at org.mortbay.io.nio.SelectChannelEndPoint.run(SelectChannelEndPoint.java:395)
    at org.mortbay.thread.QueuedThreadPool$PoolThread.run(QueuedThreadPool.java:488)

编辑:这是我今天所做的有趣观察。当事件未触发调用时,不会显示错误。具体而言,此提示是在提交表单时进行的。今天我尝试删除表单提交部分,并在调用onmodule加载函数时调用它 - 它工作正常。从服务器返回了适当的结果。但是,当我把它放回到表单提交事件中时,会出现此错误。不仅如此 - 无论何时提交表单,都会显示此错误 - 无论是否触发服务器调用。如果您提交表单一次,则会显示错误。出现第一个错误后,即使您尝试刷新页面,它也会显示出来。

3 个答案:

答案 0 :(得分:6)

我遇到了同样的问题,我最终通过删除WEB-INF \ classes的内容来修复它,因为它正在缓存那里的旧东西。

显然也尝试清除C:\ Users ... \ AppData \ Local \ Temp,因为这是一个常见的GWT问题。

答案 1 :(得分:0)

遇到与你相同的问题,我现在就解决了这个问题: 如果您的错误没有显示,如果您没有发送电话,那么因为对服务器的呼叫不起作用。 我发现客户端的JS无法正常刷新。尝试重新启动服务器,然后刷新本地缓存版本刷新浏览器。如果我的解释太复杂:清除缓存。在chrome上你可以使用crtl-f5而不仅仅是f5和firefox ctrl-R。

答案 2 :(得分:0)

我使用Maven(https://gwt-maven-plugin.github.io/gwt-maven-plugin/)初始化了GWT项目。重建Maven项目后,问题就消失了。显然有一些陈旧的文件导致冲突。