Jdk升级到11引起的问题:程序包javax.xml.bind.annotation不存在

Posted flyaway2013

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Jdk升级到11引起的问题:程序包javax.xml.bind.annotation不存在相关的知识,希望对你有一定的参考价值。


Jdk12 都发布了, 我也下载一个玩一玩吧。刚准备要下载,发现之前已经下载了一个11, 那就11 吧,也不用太新了。

安装了jdk11,习惯性的设置了一下环境变量: JAVA_HOME=D:\\tool\\jdk-11.0.2。

JAVA_HOME=D:\\Program Files\\Java\\jdk1.8.0_201

设置完了,忘记改回去了。 项目中其实使用的是jdk8,结果运行 mvn 遇到了这么一个问题, 搞了好久才解决问题。仅此记录一下!



问题是,使用cmd 执行 mvn clean install -DskipTest=true 就会有这个问题;IDEA中直接执行就正常,IDEA中 Ctrl +F9 也是正常的 。

错误是:程序包javax.xml.bind.annotation不存在:

[INFO] ------------------------------------------------------------------------
[ERROR] Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.5:compile (default-compile) on project erdp_system_domain: Compilation failure
[ERROR] /E:/dev/erdp2/erdp_system/erdp_system_domain/src/main/java/com/lk/platform/system/domain/entity/ELDict.java:[4,33] 程序包javax.xml.bind.annotation不存在
[ERROR]
[ERROR] -> [Help 1]

我晕。 刚看到这个错误的时候,简直不可思议,我擦, 怎么这个破程序,这么多bug!!!

可以看到ELDict 类中确实有一个这么的引用:import javax.xml.bind.annotation.XmlAttribute;

技术图片

 

 虽然是没有用到的,但是却引起的mvn 编译的错误。网上bing一把搜索“程序包javax.xml.bind.annotation不存在”,得到的是:

软件包 javax.xml.bind.annotation不存在-CSDN论坛
2009-12-2 · 用jaxb的到的类,不能编译,原因是: 软件包 javax.xml.bind.annotation不存在

https://bbs.csdn.net/topics/320208203
新手问题,import javax.xml.bind 编译出错-CSDN论坛
2018-6-2
软件包 org.apache.commons.fileupload不存在?-CSDN论坛
2011-5-10
软件包javax.awt,java.swing不存在,请教下原因。谢谢 ...
2009-12-29
软件包java.until不存在是怎么回事-CSDN论坛
2009-4-12
查看更多结果
gradle编译报错:程序包javax.annotation不存在 ...
2018-8-29 · 问题描述: 采用gradle命令编译(gradle build)时,报如下错误: XXXXXXXXXX.java:11: 错误: 程序包javax.annotation不存在 import javax.annotation.Nullable; 解决 ...

https://blog.csdn.net/yinxing2008/article/details/82185172
解决:Dagger2使用过程中的"程序包javax.annotation不存在 ...
2016-12-11 · 问题描述:采用gradle命令编译(gradlebuild)时,报如下错误:XXXXXXXXXX.java:11:错误:程序包javax.annotation不存在importjavax.annota... 博文 来自: yinxing2008 ...

https://blog.csdn.net/younghong1992/article/details/53575330
XmlAccessorOrder (Java 2 Platform SE 6)
2008-5-8 · 有关其他公共信息,请参阅 javax.xml.bind.package javadoc 中的“包规范”。 包上的 @XmlAccessorOrder 注释可应用于包中的所有类。继承语义的应用如下 ...

https://download.oracle.com/.../XmlAccessorOrder.html
java – 包org.apache.hadoop.fs不存在 - 程序园
2019-1-21 · java – 包com.sun.xml.internal.bind.v2.model.annotation不存在 3. java – 包不存在错误 ... 程序包javax.servlet.annotation不存在 8. 软件包 javax.servlet 不存在 包android ...

www.voidcn.com/article/p-abbxrldb-bup.html
错误: 程序包com.sun.xml.internal.bind.v2.schemagen ...
2014-6-21 · 问题描述: 用ant来构建程序时报如下错误: 错误: 程序包com.sun.xml.internal.bind.v2.schemagen.xmlschema不存在 [javac] import com.sun.xml.internal.bind ...

www.voidcn.com/article/p-ftnsltjy-bca.html
javax.xml.bind.jar-CSDN下载
2013-8-22 · 软件包 javax.xml.bind.annotation不存在 新手问题,import javax.xml.bind 编译出错 javax.xml.bind 和javax.xml.bind.annotation.XmlType问题 真正解决方案:java.lang ...

貌似少了什么软件包? 可是, javax.xml.bind.annotation.XmlAttribute 是确实可以直接访问的,是直接存在于 jdk8 之中的, 应该不需要说明其他的 jar 吧。 另外注意但 第一个答案是 2009 年的了, 那个时候可能没有包含在 jdk之中吧。。。  直觉告诉我,可能是 jdk 版本的问题,

执行java -version,返回是:

java -version
java version "1.8.0_201"
Java(TM) SE Runtime Environment (build 1.8.0_201-b09)
Java HotSpot(TM) 64-Bit Server VM (build 25.201-b09, mixed mode)

好像没有什么问题啊!!

 

看来是个麻烦的问题,貌似大家都没有遇到过。(好像还真是如此。。)。不得已,暂时只能在IDEA运行maven。 但是这个问题一直困扰着我。。 bing 搜索javax.xml.bind.annotation does not exist, 终于看到了答案:

第一个就是 答案: https://stackoverflow.com/questions/52502189/java-11-package-javax-xml-bind-does-not-exist

According to the release-notes, Java 11 removed the Java EE modules:

java.xml.bind (JAXB) - REMOVED
Java 8 - OK
Java 9 - DEPRECATED
Java 10 - DEPRECATED
Java 11 - REMOVED
See JEP 320 for more info.

原来已经被删除了!

第二个,其实验证我的想法, JAXB ( 应该就是 javax.xml.bind.annotation 包)在之前是不直接属于jdk的,需要而且的jar 引入。  https://stackoverflow.com/questions/2895777/does-jaxb-work-under-java-5 

实际上可以这么引入:

<dependency>
  <groupId>javax.xml.bind</groupId>
  <artifactId>jaxb-api</artifactId>
  <version>2.3.0</version>
</dependency>
<dependency>
  <groupId>com.sun.xml.bind</groupId>
  <artifactId>jaxb-core</artifactId>
  <version>2.3.0</version>
</dependency>
<dependency>
  <groupId>com.sun.xml.bind</groupId>
  <artifactId>jaxb-impl</artifactId>
  <version>2.3.0</version>
</dependency>

 

但是,到了11, JAXB这个功能又被去掉了。。 所以,有必要的话,还是需要手动引入那些个jar。

 

定睛一看,发现JAVA_HOME有问题,JAVA_HOME=D:\\tool\\jdk-11.0.2 ;终于 想起了之前的改动。测试一把。修改JAVA_HOME,

set JAVA_HOME=wa, 再运行 mvn,出现:

E:\\dev\\erdp2\\erdp_base\\erdp_modules>call mvn clean install -DskipTest=true
The JAVA_HOME environment variable is not defined correctly
This environment variable is needed to run this program
NB: JAVA_HOME should point to a JDK not a JRE
请按任意键继续. . .

可见 mvn 确实会直接读取 JAVA_HOME

 

但为什么 java -version 确实正确的呢? 查看path:

Path=.;D:\\tool\\apache-maven-3.6.1\\bin;D:\\tool\\mysql-5.7.23-winx64\\bin;C:\\Program Files (x86)\\Common Files\\Oracle\\Java\\javapath;D:\\tool\\jdk-11.0.2\\bin;C:\\ProgramData\\Oracle\\Java\\javapath;C:\\WINDOWS\\system32;C:\\WINDOWS;C:\\WINDOWS\\System32\\Wbem;C:\\WINDOWS\\System32\\WindowsPowerShell\\v1.0\\;d:\\Program Files\\Git\\cmd;C:\\Program Files (x86)\\ATI Technologies\\ATI.ACE\\Core-Static;C:\\WINDOWS\\System32\\OpenSSH\\;C:\\ProgramData\\chocolatey\\bin;C:\\Users\\Administrator\\AppData\\Local\\Microsoft\\WindowsApps

原来 path先是查找到 C:\\Program Files (x86)\\Common Files\\Oracle\\Java\\javapath , C:\\Program Files (x86)\\Common Files\\Oracle\\Java\\javapath\\java -version 返回就是 java version "1.8.0_201" !!

 

但是呢, maven 却是直接读取JAVA_HOME  环境变量的, 所以出现了 jdk 误以为设置正确的假象!( 其实是没有设置正确! )

 

再修改JAVA_HOME 为jdk8 :
set JAVA_HOME=D:\\Program Files\\Java\\jdk1.8.0_201

再运行maven 程序, 正!常!了!

 


总结,看了jdk 也不能乱升级,虽然说Java的向后兼容做得非常非常好, 但是也不是100%兼容!特别是 javax 的一些内容,很多都是实验性质的!。。


 

以上是关于Jdk升级到11引起的问题:程序包javax.xml.bind.annotation不存在的主要内容,如果未能解决你的问题,请参考以下文章

Linux 怎么把jdk10升级到jdk11

将 Spring Boot 项目从 JDK 8 升级到 JDK 11

求xp安装jdk方法,最新版叫我升级,求一个可以使用的

jdk1.8 升级到 jdk11 遇到的一些坑

jdk8升级jdk11踩坑记录1

java选的jdk11为啥变成了17