Google App Engine - calling new Gson() creates "java.lang.VerifyError: Cannot inherit from final class"
Google App Engine - calling new Gson() creates "java.lang.VerifyError: Cannot inherit from final class"
这在本地调试时有效,但一旦部署任何对 new Gson() 的 servlet 调用都会产生此错误。我无法 google 修复它。什么可以解决这个问题?
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.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 构建路径。重置后,我现在可以选择依赖 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);
}
但以下代码远程工作正常,但有令人不安的消息:
"Use of com.google.appengine.repackaged may result in your app breaking without warning."
赞
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);
}
你确定你输入的是正确的吗?
请记住,App Engine SDK 包含重新打包的 Gson 版本。
com.google.appengine.repackaged.com.google.gson.Gson
添加您自己的 Gson 依赖项并确保导入指向此依赖项而不是重新打包的版本。
我们在其他一些 jar 中遇到了类似的问题。原因是序列化所需的 Jackson 库的 jar 版本相互冲突。
我们做了什么:
- 在我们的 (Maven) 项目中添加了 enforcer 插件
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-enforcer-plugin</artifactId>
<version>1.4.1</version>
<configuration>
<rules><dependencyConvergence/></rules>
</configuration>
</plugin>
运行 项目执行者
$ mvn enforcer:enforce
根据执法者的建议采取了补救措施
鉴于我们的项目相当大,我们有大约 20 个奇怪的 jar 存在冲突,这些 jar 用于来自不同依赖关系图的不同版本。一次参加一个,尤其是。那些我们怀疑的。
这得到了回报。我们回到 运行 应用程序非常好。
这在本地调试时有效,但一旦部署任何对 new Gson() 的 servlet 调用都会产生此错误。我无法 google 修复它。什么可以解决这个问题?
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.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 构建路径。重置后,我现在可以选择依赖 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);
}
但以下代码远程工作正常,但有令人不安的消息:
"Use of com.google.appengine.repackaged may result in your app breaking without warning."
赞
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);
}
你确定你输入的是正确的吗?
请记住,App Engine SDK 包含重新打包的 Gson 版本。
com.google.appengine.repackaged.com.google.gson.Gson
添加您自己的 Gson 依赖项并确保导入指向此依赖项而不是重新打包的版本。
我们在其他一些 jar 中遇到了类似的问题。原因是序列化所需的 Jackson 库的 jar 版本相互冲突。 我们做了什么:
- 在我们的 (Maven) 项目中添加了 enforcer 插件
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-enforcer-plugin</artifactId>
<version>1.4.1</version>
<configuration>
<rules><dependencyConvergence/></rules>
</configuration>
</plugin>
运行 项目执行者
$ mvn enforcer:enforce
根据执法者的建议采取了补救措施 鉴于我们的项目相当大,我们有大约 20 个奇怪的 jar 存在冲突,这些 jar 用于来自不同依赖关系图的不同版本。一次参加一个,尤其是。那些我们怀疑的。
这得到了回报。我们回到 运行 应用程序非常好。