HTTP状态500 - java.lang.NoClassDefFoundError:JAVA /时间OpenShift

问题描述:

我了解RESTful Web服务上运行应用程序时/时间/ TemporalField,我建立一个简单的OpenShiftHTTP状态500 - java.lang.NoClassDefFoundError:JAVA /时间OpenShift

的免费主机

在App我OpenShift上的服务器和数据库:jbossews-2.0(Tomcat 7); PostgreSQL的-9.2 This is my lib

当我在本地主机测试我不明白的错误,但是当我运行OpenShift主机应用程序I在页面上看到:

HTTP Status 500 - java.lang.NoClassDefFoundError: java/time/temporal/TemporalField 

type Exception report 

message java.lang.NoClassDefFoundError: java/time/temporal/TemporalField 

description The server encountered an internal error that prevented it from fulfilling this request. 

exception 

javax.servlet.ServletException: java.lang.NoClassDefFoundError: java/time/temporal/TemporalField 
    com.sun.jersey.spi.container.servlet.WebComponent.service(WebComponent.java:420) 
    com.sun.jersey.spi.container.servlet.ServletContainer.service(ServletContainer.java:558) 
    com.sun.jersey.spi.container.servlet.ServletContainer.service(ServletContainer.java:733) 
    javax.servlet.http.HttpServlet.service(HttpServlet.java:727) 
    org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52) 

root cause 

java.lang.NoClassDefFoundError: java/time/temporal/TemporalField 
    org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:320) 
    org.postgresql.Driver.makeConnection(Driver.java:406) 
    org.postgresql.Driver.connect(Driver.java:274) 
    java.sql.DriverManager.getConnection(DriverManager.java:571) 
    java.sql.DriverManager.getConnection(DriverManager.java:215) 
    service.TestService.main(TestService.java:126) 
    sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
    sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57) 
    sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) 
    java.lang.reflect.Method.invoke(Method.java:606) 
    com.sun.jersey.spi.container.JavaMethodInvokerFactory$1.invoke(JavaMethodInvokerFactory.java:60) 
    com.sun.jersey.server.impl.model.method.dispatch.AbstractResourceMethodDispatchProvider$TypeOutInvoker._dispatch(AbstractResourceMethodDispatchProvider.java:185) 
    com.sun.jersey.server.impl.model.method.dispatch.ResourceJavaMethodDispatcher.dispatch(ResourceJavaMethodDispatcher.java:75) 
    com.sun.jersey.server.impl.uri.rules.HttpMethodRule.accept(HttpMethodRule.java:302) 
    com.sun.jersey.server.impl.uri.rules.ResourceClassRule.accept(ResourceClassRule.java:108) 
    com.sun.jersey.server.impl.uri.rules.RightHandPathRule.accept(RightHandPathRule.java:147) 
    com.sun.jersey.server.impl.uri.rules.RootResourceClassesRule.accept(RootResourceClassesRule.java:84) 
    com.sun.jersey.server.impl.application.WebApplicationImpl._handleRequest(WebApplicationImpl.java:1542) 
    com.sun.jersey.server.impl.application.WebApplicationImpl._handleRequest(WebApplicationImpl.java:1473) 
    com.sun.jersey.server.impl.application.WebApplicationImpl.handleRequest(WebApplicationImpl.java:1419) 
    com.sun.jersey.server.impl.application.WebApplicationImpl.handleRequest(WebApplicationImpl.java:1409) 
    com.sun.jersey.spi.container.servlet.WebComponent.service(WebComponent.java:409) 
    com.sun.jersey.spi.container.servlet.ServletContainer.service(ServletContainer.java:558) 
    com.sun.jersey.spi.container.servlet.ServletContainer.service(ServletContainer.java:733) 
    javax.servlet.http.HttpServlet.service(HttpServlet.java:727) 
    org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52) 

root cause 

java.lang.ClassNotFoundException: java.time.temporal.TemporalField 
    org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1720) 
    org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1571) 
    org.postgresql.jdbc.PgConnection.<init>(PgConnection.java:320) 
    org.postgresql.Driver.makeConnection(Driver.java:406) 
    org.postgresql.Driver.connect(Driver.java:274) 
    java.sql.DriverManager.getConnection(DriverManager.java:571) 
    java.sql.DriverManager.getConnection(DriverManager.java:215) 
    service.TestService.main(TestService.java:126) 
    sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
    sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57) 
    sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) 
    java.lang.reflect.Method.invoke(Method.java:606) 
    com.sun.jersey.spi.container.JavaMethodInvokerFactory$1.invoke(JavaMethodInvokerFactory.java:60) 
    com.sun.jersey.server.impl.model.method.dispatch.AbstractResourceMethodDispatchProvider$TypeOutInvoker._dispatch(AbstractResourceMethodDispatchProvider.java:185) 
    com.sun.jersey.server.impl.model.method.dispatch.ResourceJavaMethodDispatcher.dispatch(ResourceJavaMethodDispatcher.java:75) 
    com.sun.jersey.server.impl.uri.rules.HttpMethodRule.accept(HttpMethodRule.java:302) 
    com.sun.jersey.server.impl.uri.rules.ResourceClassRule.accept(ResourceClassRule.java:108) 
    com.sun.jersey.server.impl.uri.rules.RightHandPathRule.accept(RightHandPathRule.java:147) 
    com.sun.jersey.server.impl.uri.rules.RootResourceClassesRule.accept(RootResourceClassesRule.java:84) 
    com.sun.jersey.server.impl.application.WebApplicationImpl._handleRequest(WebApplicationImpl.java:1542) 
    com.sun.jersey.server.impl.application.WebApplicationImpl._handleRequest(WebApplicationImpl.java:1473) 
    com.sun.jersey.server.impl.application.WebApplicationImpl.handleRequest(WebApplicationImpl.java:1419) 
    com.sun.jersey.server.impl.application.WebApplicationImpl.handleRequest(WebApplicationImpl.java:1409) 
    com.sun.jersey.spi.container.servlet.WebComponent.service(WebComponent.java:409) 
    com.sun.jersey.spi.container.servlet.ServletContainer.service(ServletContainer.java:558) 
    com.sun.jersey.spi.container.servlet.ServletContainer.service(ServletContainer.java:733) 
    javax.servlet.http.HttpServlet.service(HttpServlet.java:727) 
    org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52) 

PS:我改变文件postgresql-9.4.1208.jar(用于jdk 8)到我的WEB-INF库中的prostgresql-9.4.1208.jre7.jar(用于jdk 7),现在一切正常。 非常感谢大家!玩的很开心 !!!

+0

您使用哪种jboss墨盒? –

+1

'java.time.temporal.TemporalField'仅在Java 1.8以后才存在。 – Berger

根据Java docstime/temporal/TemporalField已于版本1.8

介绍我创建一个Tomcat 7(JBoss的EWS 2.0)的墨盒并检查版本:

$ ssh $MY_APP 
$ java -version 
java version "1.7.0_95" 
+0

是的,我也这么认为。但我无法找到问题的解决方案:((( – TearsRiver

+0

完成,感谢您的帮助;) – TearsRiver

更改为9.4.1208.jre7解决了我问题,似乎他们编译为jdk8

在我的情况下(SLES 11.3上的Tomcat 8),事实证明,虽然我已经安装了Java 8 SDK而不卸载Java 7,并相应地设置了JAVA_HOME,但JRE_HOME是s直到指向我的Java 7安装。解决这个问题。