Google App Engine - 调用新的Gson()创建“java.lang.VerifyError:无法继承最终类”

时间:2015-01-11 20:50:44

标签: google-app-engine gson

这在本地调试时有效,但一旦部署了对新Gson()的任何servlet调用就会产生此错误。我无法谷歌修复它。什么能解决问题?

import com.google.gson.Gson;
import com.google.gson.GsonBuilder;

public void doGet(HttpServletRequest req, HttpServletResponse resp) throws IOException {    
    Gson gson = new Gson();
    resp.setContentType("text/plain");
    resp.getWriter().println("Service started.");
}


Uncaught exception from servlet
java.lang.VerifyError: Cannot inherit from final class
    at com.google.appengine.runtime.Request.process-753f125056d26ae3(Request.java)
    at java.lang.ClassLoader.defineClass1(Native Method)
    at java.lang.ClassLoader.defineClass(ClassLoader.java:809)
    at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:142)
    at java.net.URLClassLoader.defineClass(URLClassLoader.java:449)
    at sun.reflect.GeneratedMethodAccessor5.invoke(Unknown Source)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:606)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:374)
    at com.selectshotgolf.game.SelectShotServlet.doGet(SelectShotServlet.java:17)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:617)
    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.googlecode.objectify.ObjectifyFilter.doFilter(ObjectifyFilter.java:48)
    at org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1157)
    at org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1157)
    at org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1157)
    at org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1157)
    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 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.headerComplete(HttpConnection.java:923)
    at org.mortbay.jetty.HttpConnection.handle(HttpConnection.java:404)
    at com.google.tracing.TraceContext$TraceContextRunnable.runInContext(TraceContext.java:438)
    at com.google.tracing.TraceContext$TraceContextRunnable$1.run(TraceContext.java:445)
    at com.google.tracing.CurrentContext.runInContext(CurrentContext.java:220)
    at com.google.tracing.TraceContext$AbstractTraceContextCallback.runInInheritedContextNoUnref(TraceContext.java:309)
    at com.google.tracing.TraceContext$AbstractTraceContextCallback.runInInheritedContext(TraceContext.java:301)
    at com.google.tracing.TraceContext$TraceContextRunnable.run(TraceContext.java:442)
    at java.lang.Thread.run(Thread.java:724)

这也适用于本地或部署:

import com.google.gson.Gson;

public void doGet(HttpServletRequest req, HttpServletResponse resp) throws IOException {    
    new JsonObject();
    resp.setContentType("text/plain");
    resp.getWriter().println("Service started.");
}

*编辑

我让Eclipse立刻更新自己,重启后我不得不重置App Engine Java Build Path。重置后,我现在可以选择依赖com.google.gson.Gson或重新包装。

这仍然会引发上述错误:

import com.google.gson.GsonBuilder;

    public <T> T fromJson(String paramName, Class<T> clazz){
        if(gson == null)
            gson = new GsonBuilder().excludeFieldsWithoutExposeAnnotation().create();

        return gson.fromJson(req.getParameter(paramName), clazz);
    }

但是以下代码可以正常工作,但有令人不安的消息:

“使用com.google.appengine.repackaged可能会导致您的应用无法发出警告。”

亚克西

import com.google.appengine.repackaged.com.google.gson.GsonBuilder;

    public <T> T fromJson(String paramName, Class<T> clazz){
        if(gson == null)
            gson = new GsonBuilder().excludeFieldsWithoutExposeAnnotation().create();

        return gson.fromJson(req.getParameter(paramName), clazz);
    }

2 个答案:

答案 0 :(得分:0)

你确定你的进口是正确的吗?

请记住,App Engine SDK包含重新打包的Gson版本。

com.google.appengine.repackaged.com.google.gson.Gson

添加您自己的Gson依赖项,并确保导入指向此依赖项而非重新打包版本。

答案 1 :(得分:0)

其他一些罐子也遇到了类似的问题。原因是用于序列化目的的Jackson库的jar版本相互冲突。 我们做了什么:

  1. 在我们的(Maven)项目中添加了执行器插件
<plugin> 
      <groupId>org.apache.maven.plugins</groupId>
                        <artifactId>maven-enforcer-plugin</artifactId>
                        <version>1.4.1</version>
                        <configuration>
                            <rules><dependencyConvergence/></rules>
                        </configuration>
                    </plugin>
  1. Ran执行程序在项目上

    $ mvn执行器:强制

  2. 根据执行者的建议采取补救措施 考虑到我们的项目相当庞大,对于来自不同依赖关系图的不同版本,我们有大约20个奇怪的jars在冲突中。一次参加一次,特别是。那些我们对此表示怀疑的人。

这还清了。我们回到了运行该应用程序的完美状态。