【问题标题】:GWT Error: java.lang.NoClassDefFoundError: com/google/gwt/core/client/GWTBridgeGWT 错误:java.lang.NoClassDefFoundError:com/google/gwt/core/client/GWTBridge
【发布时间】:2014-03-28 07:48:20
【问题描述】:

我在一个班级项目中使用 GWT,虽然之前一切正常,但我最近重构了我的代码,突然我遇到了标题错误。我四处搜索,似乎 GWTBridge 问题是由 2 个主要问题引起的:a) 为 2.5.1 修复的错误,或 b) 尝试从服务器调用客户端代码,反之亦然 (classNotFoundException GWTBridge) .

我正在使用 GWT 2.5.1,我 99% 确定我没有违反案例 b),所以我很茫然。我实际上只是在重构时从工作版本中复制和粘贴代码,所以我不确定问题出在哪里。

我的直觉是它可能与我在重构时创建的两个静态 Singleton 类有关。我在重构时的目标只是让 RPC 不那么混乱,因为它迫使我链接一堆异步调用,这让我发疯了。我基本上所做的是创建两个静态单例类(PageLoader 和 UserManager),其目的是进行异步调用并返回 OnSuccess 返回的任何内容,以便在 onModuleLoad 中我可以进行连续的 RPC 调用而无需处理链接(例如,我可以只需转到 UserManager.getInstance().isLoggedIn() 然后稍后在 RPC 调用中使用返回的布尔值,而不必将该调用放在 onSuccess 函数中)。我将这两个类与我的 Async 类一起放在 client.services 中。

我不知道为什么这会导致问题,但我想不出其他任何事情。知道我是否走在正确的轨道上吗?

我在下面附加了一个静态类和返回的堆栈跟踪的一部分。


用户管理器类

package com.google.gwt.sample.vendorcouver.client.services;

import com.google.gwt.core.client.GWT;
import com.google.gwt.sample.vendorcouver.client.user.VenUser;
import com.google.gwt.user.client.Window;
import com.google.gwt.user.client.rpc.AsyncCallback;


/*Singleton that simplifies making asynchronous calls to the server side.*/

public class UserManager {

    private static UserManager UserManagerInstance = null;
    private static LoginServiceAsync LoginServiceInstance = null;
    private static VenUserServiceAsync VenUserServiceInstance = null;
    private static boolean isLoggedIn = false;
    private static boolean isAdmin = false;
    private static String UserName = null;


    public static UserManager getInstance()
    {
        if (UserManagerInstance == null)
        {
            UserManagerInstance = new UserManager();
            LoginServiceInstance = GWT.create(LoginService.class);
            VenUserServiceInstance = GWT.create(VenUserService.class);
        }
        return UserManagerInstance;
    }

    public boolean isLoggedIn()
    {
        LoginServiceInstance.isLoggedIn(new AsyncCallback<Boolean>() {
            public void onFailure(Throwable error) {
                Window.alert("Sorry, there seemed to be an error on the server side! You may be unable to log in.");
            }
            public void onSuccess(Boolean loggedInStatus) {
                Window.alert("isLoggedIn is sucessful; will return" + loggedInStatus);
                isLoggedIn = loggedInStatus;
            }
        });
        return isLoggedIn;
    }

堆栈跟踪:

   SEVERE: javax.servlet.ServletContext log: Exception while dispatching incoming RPC call
com.google.gwt.user.server.rpc.UnexpectedException: Service method 'public abstract boolean com.google.gwt.sample.vendorcouver.client.services.LoginService.isLoggedIn()' threw an unexpected exception: java.lang.NoClassDefFoundError: com/google/gwt/core/client/GWTBridge
    at com.google.gwt.user.server.rpc.RPC.encodeResponseForFailure(RPC.java:389)
    at com.google.gwt.user.server.rpc.RPC.invokeAndEncodeResponse(RPC.java:579)
    at com.google.gwt.user.server.rpc.RemoteServiceServlet.processCall(RemoteServiceServlet.java:208)
    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:511)
    at org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1166)
    at com.google.appengine.api.socket.dev.DevSocketFilter.doFilter(DevSocketFilter.java:74)
    at org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1157)
    at com.google.appengine.tools.development.ResponseRewriterFilter.doFilter(ResponseRewriterFilter.java:123)
    at org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1157)
    at com.google.appengine.tools.development.HeaderVerificationFilter.doFilter(HeaderVerificationFilter.java:34)
    at org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1157)
    at com.google.appengine.api.blobstore.dev.ServeBlobFilter.doFilter(ServeBlobFilter.java:63)
    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:125)
    at org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1157)
    at com.google.appengine.tools.development.DevAppServerModulesFilter.doDirectRequest(DevAppServerModulesFilter.java:366)
    at com.google.appengine.tools.development.DevAppServerModulesFilter.doDirectModuleRequest(DevAppServerModulesFilter.java:349)
    at com.google.appengine.tools.development.DevAppServerModulesFilter.doFilter(DevAppServerModulesFilter.java:116)
    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.appengine.tools.development.DevAppEngineWebAppContext.handle(DevAppEngineWebAppContext.java:97)
    at org.mortbay.jetty.handler.HandlerWrapper.handle(HandlerWrapper.java:152)
    at com.google.appengine.tools.development.JettyContainerService$ApiProxyHandler.handle(JettyContainerService.java:487)
    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:218)
    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)
Caused by: java.lang.NoClassDefFoundError: com/google/gwt/core/client/GWTBridge
    at com.google.gwt.user.client.Window.<clinit>(Window.java:504)
    at java.lang.Class.forName0(Native Method)
    at java.lang.Class.forName(Unknown Source)
    at com.google.appengine.tools.development.agent.runtime.RuntimeHelper.checkRestricted(RuntimeHelper.java:70)
    at com.google.appengine.tools.development.agent.runtime.Runtime.checkRestricted(Runtime.java:64)
    at com.google.gwt.sample.vendorcouver.server.LoginServiceImpl.isLoggedIn(LoginServiceImpl.java:17)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
    at java.lang.reflect.Method.invoke(Unknown Source)
    at com.google.appengine.tools.development.agent.runtime.Runtime.invoke(Runtime.java:115)
    at com.google.gwt.user.server.rpc.RPC.invokeAndEncodeResponse(RPC.java:561)
    ... 40 more
Caused by: java.lang.ClassNotFoundException: com.google.gwt.core.client.GWTBridge
    at java.net.URLClassLoader$1.run(Unknown Source)
    at java.net.URLClassLoader$1.run(Unknown Source)
    at java.security.AccessController.doPrivileged(Native Method)
    at java.net.URLClassLoader.findClass(Unknown Source)
    at java.lang.ClassLoader.loadClass(Unknown Source)
    at com.google.appengine.tools.development.IsolatedAppClassLoader.loadClass(IsolatedAppClassLoader.java:216)
    at java.lang.ClassLoader.loadClass(Unknown Source)
    ... 52 more

【问题讨论】:

    标签: java google-app-engine gwt classnotfoundexception


    【解决方案1】:

    堆栈跟踪很清楚:您正在尝试使用 com.google.gwt.sample.vendorcouver.server.LoginServiceImpl#isLoggedIn(服务器端代码)中的 com.google.gwt.user.client.Window(客户端)类


    顺便说一句,您确实意识到您的UserManager#isLoggedIn 在第一次被调用时会总是返回false,对吧? (由于 RPC 调用的异步性质)

    【讨论】:

    • 啊,你是对的!我没有意识到那会是个问题。你能扩展你的第二条评论吗?我不明白为什么 isLoggedIn() 总是返回 false。为什么 RPC 调用是异步的,一开始总是返回 false?
    • 当你第一次调用isLoggedIn()时,你发出了一个异步的RPC请求,因为它是异步的,控制权在响应返回之前返回到isLoggedIn(),所以return isLoggedIn返回初始isLoggedIn 的值,即false。然后几毫秒后,响应从服务器返回,isLoggedIn 被更新(假设为true)。下次调用 isLoggedIn() 时,您会创建一个新的 RPC 并返回 isLoggedInprevious 值(即 true),然后几毫秒后响应到达并更新 isLoggedIn .
    【解决方案2】:

    在您的项目中添加以下内容(确保包正确):

    package com.google.gwt.core.client;
    import com.google.gwt.core.shared.*;
    /**
    * Date: 1/17/13
    * Time: 12:37 PM
    * This class is used for fixing class not found com.google.gwt.core.client.GWTBridge;
    *
    * This is only needed for GXT 2 to work. Once we remove GXT2, this can be removed also.
    */
    public abstract class GWTBridge extends com.google.gwt.core.shared.GWTBridge {
    }
    

    原文:http://alexluca.com/2013/01/17/gwt-25-and-extgwt-224-classnotfoundexception-comgooglegwtcoreclientgwtbridge/

    【讨论】:

      【解决方案3】:

      Window.alert 在服务器端也是不允许的。

      【讨论】:

        猜你喜欢
        • 1970-01-01
        • 1970-01-01
        • 2013-08-23
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 2013-01-05
        相关资源
        最近更新 更多