com/microsoft/sqlserver/jdbc/SQLServerDriver has been compiled by a more recent version of the Java

目录

 

1.故事是这样开始的

2.发生事故的瞬间

3.事故疑云

4.事件追踪


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.事件追踪

预知结果如何,且听下回分解,敬请期待。


 

  • 20
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 9
    评论
评论 9
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

张3蜂

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值