com/microsoft/sqlserver/jdbc/SQLServerDriver has been compiled by a more recent version of the Java
目录
1.故事是这样开始的
我想做一个可执行的jar包,把jar以服务的方式允许。在jar的代码中我采用JDBC SQLServer驱动来连接Sqlserver数据库;在我的本机已经连接数据库成功,但是向linux服务器部署可执行jar的过程中,遇到了难题。
2.发生事故的瞬间
做好了可执行的jar,向linux服务器部署可执行jar的过程中,报了如下错误:
Exception in thread "main" java.lang.UnsupportedClassVersionError: com/microsoft/sqlserver/jdbc/SQLServerDriver has been compiled by a more recent version of the Java Runtime (class file version 54.0), this version of the Java Runtime only recognizes class file versions up to 52.0
at java.lang.ClassLoader.defineClass1(Native Method)
at java.lang.ClassLoader.defineClass(ClassLoader.java:763)
at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:142)
at java.net.URLClassLoader.defineClass(URLClassLoader.java:467)
at java.net.URLClassLoader.access$100(URLClassLoader.java:73)
at java.net.URLClassLoader$1.run(URLClassLoader.java:368)
at java.net.URLClassLoader$1.run(URLClassLoader.java:362)
at java.security.AccessController.doPrivileged(Native Method)
at java.net.URLClassLoader.findClass(URLClassLoader.java:361)
at java.lang.ClassLoader.loadClass(ClassLoader.java:424)
at java.lang.ClassLoader.loadClass(ClassLoader.java:411)
at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:338)
at java.lang.ClassLoader.loadClass(ClassLoader.java:357)
at java.lang.Class.forName0(Native Method)
at java.lang.Class.forName(Class.java:264)
at com.sdb.netool.SqlServerHelper.GetTransferDetailsWaitPay(SqlServerHelper.java:23)
at com.sdb.netool.PayService.main(PayService.java:39)
3.事故疑云
(1)异常中说com/microsoft/sqlserver/jdbc/SQLServerDriver.class 被重新编译成了“class file version 54.0”。
网上找到了一种方法查看*.class文件的file version。step1:根据异常找到编译后的.class文件。step2:采用javap -verbose classname。经过查看,发现major version: 52,并没有错误。这和异常中说的不一致矛盾啊?但是程序是不会骗人的,不会说谎的,那么这种class file version52和54的不匹配,到底发生在什么地方呢?
(2)jdk版本不匹配?
linux服务器:java version "1.8.0_161"
个人电脑:java version "1.8.0_73"
都是1.8,我觉得不会是jdk的问题。异常信息里也没有提示jdk版本不匹配。
4.事件追踪
预知结果如何,且听下回分解,敬请期待。
更多推荐
所有评论(0)