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 也是正常的(我的IDEA的java 的版本是8) 。

错误是:程序包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:[,] 程序包javax.xml.bind.annotation不存在
[ERROR]
[ERROR] -> [Help ]

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

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

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

软件包 javax.xml.bind.annotation不存在-CSDN论坛
-- · 用jaxb的到的类,不能编译,原因是: 软件包 javax.xml.bind.annotation不存在 https://bbs.csdn.net/topics/320208203
新手问题,import javax.xml.bind 编译出错-CSDN论坛
--
软件包 org.apache.commons.fileupload不存在?-CSDN论坛
--
软件包javax.awt,java.swing不存在,请教下原因。谢谢 ...
--
软件包java.until不存在是怎么回事-CSDN论坛
--
查看更多结果
gradle编译报错:程序包javax.annotation不存在 ...
-- · 问题描述: 采用gradle命令编译(gradle build)时,报如下错误: XXXXXXXXXX.java:: 错误: 程序包javax.annotation不存在 import javax.annotation.Nullable; 解决 ... https://blog.csdn.net/yinxing2008/article/details/82185172
解决:Dagger2使用过程中的"程序包javax.annotation不存在 ...
-- · 问题描述:采用gradle命令编译(gradlebuild)时,报如下错误:XXXXXXXXXX.java::错误:程序包javax.annotation不存在importjavax.annota... 博文 来自: yinxing2008 ... https://blog.csdn.net/younghong1992/article/details/53575330
XmlAccessorOrder (Java Platform SE )
-- · 有关其他公共信息,请参阅 javax.xml.bind.package javadoc 中的“包规范”。 包上的 @XmlAccessorOrder 注释可应用于包中的所有类。继承语义的应用如下 ... https://download.oracle.com/.../XmlAccessorOrder.html
java – 包org.apache.hadoop.fs不存在 - 程序园
-- · java – 包com.sun.xml.internal.bind.v2.model.annotation不存在 . java – 包不存在错误 ... 程序包javax.servlet.annotation不存在 . 软件包 javax.servlet 不存在 包android ... www.voidcn.com/article/p-abbxrldb-bup.html
错误: 程序包com.sun.xml.internal.bind.v2.schemagen ...
-- · 问题描述: 用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下载
-- · 软件包 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 版本的问题,因为我在IDEA中执行mvn就是正常的,我的IDEA的java 的版本是8。

执行java -version,返回是:

java -version
java version "1.8.0_201"
Java(TM) SE Runtime Environment (build 1.8.0_201-b09)
Java HotSpot(TM) -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  removed the Java EE modules:

java.xml.bind (JAXB) - REMOVED
Java - OK
Java - DEPRECATED
Java - DEPRECATED
Java - REMOVED
See JEP 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.</version>
</dependency>
<dependency>
<groupId>com.sun.xml.bind</groupId>
<artifactId>jaxb-core</artifactId>
<version>2.3.</version>
</dependency>
<dependency>
<groupId>com.sun.xml.bind</groupId>
<artifactId>jaxb-impl</artifactId>
<version>2.3.</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不存在的更多相关文章

  1. java编译错误 程序包javax.servlet不存在javax.servlet.*

    java编译错误 程序包javax.servlet不存在javax.servlet.* 编译:javac Servlet.java 出现 软件包 javax.servlet 不存在 软件包javax. ...

  2. 程序包javax.servlet.http不存在

    在maven test项目时,出现错误: java:[7,26] 程序包javax.servlet.http不存在 原因:pom.xml中未引入javax.servlert-api相关的包 <d ...

  3. java.util.concurrent.ExecutionException: org.apache.catalina.LifecycleException or 程序包 javax.servlet 不存在

    遇到下面这个问题 程序包 javax.servlet 不存在 或者 java.util.concurrent.ExecutionException: org.apache.catalina.Lifec ...

  4. 程序包javax.servlet.annotation不存在

    1.错误描写叙述 [INFO] Scanning for projects... [INFO] [INFO] --------------------------------------------- ...

  5. 解决Idea项目启动报错:程序包javax.servlet.http不存在

    报错信息 在没有使用maven的时候,web项目从远程仓库获取下以后,起一次启动往往会报错javax.servlet.http程序包找不到,随之而来的java基础包都将不能使用,报错信息如下: 解决方 ...

  6. 【转】java编译错误 程序包javax.servlet不存在javax.servlet.*

    转载地址:http://blog.163.com/gis_warrior/blog/static/1936171732012811071642/ 编译:javac Servlet.java 出现 软件 ...

  7. maven install 时提示“程序包 javax.crypto不存在”

    但是javax.crypto是在jdk的jre\lib目录下的 解决方案: <compilerArguments> <bootclasspath>${java.home}/li ...

  8. MAVEN打包报错:com.sun.net.ssl.internal.ssl;sun.misc.BASE64Decoder;程序包 javax.crypto不存在处理办法

    以下是pom.xml里面的完整配置,重点是红色的部分,原因是引用的jar是jre下边的,而打包环境用的是jdk下边的jar,所以引用下就OK了.<build> <plugins> ...

  9. 程序包 javax.servlet 不存在 解决办法

    其原因是java编译器没有找到软件包javax.servlet. 下载servlet.jar放到lib下没有效果,后发现需要在jdk中添加,如下: 解决办法: 从tomcat lib目录下拷贝一个se ...

随机推荐

  1. Idea_学习_01_Idea激活

    一.激活—激活码 下载地址:官网 1.注册码 http://idea.lanyus.com/ 二.激活—license server 1. (推荐) 弹窗中选择最后一个页面license server ...

  2. 常规DLL与扩展DLL区别

    1.常规DLL可以被各种程序(python,VB等)调用,扩展DLL只能被MFC程序调用.提供给外部使用的控件类只能用扩展DLL. 2.扩展DLL的入口函数是DllMain(),而常规DLL入口是继承 ...

  3. linux命令学习笔记(6):rmdir 命令

    今天学习一下linux中命令: rmdir命令.rmdir是常用的命令,该命令的功能是删除空目录,一个目录 被删除之前必须是空的.(注意,rm - r dir命令可代替rmdir,但是有很大危险性.) ...

  4. 使用MDI窗体实现多窗口效果

    本文章已收录于:   C#MDI窗体实现多窗口效果   Visual C#是微软公司推出的下一代主流程序开发语言,他也是一种功能十分强大的程 序设计语言,正在受到越来越多的编程人员的喜欢.在Visua ...

  5. Asp.net工作流workflow实战之书签(二)

    1.winform(web程序)下使用工作流 怎样才能像控制台那样让winform或web页面窗体阻塞等待工作流的继续执行呢 2.BookMark书签 书签:和一般的书签看书的时候方便查看上次看的内容 ...

  6. Poj 2411 Mondriaan's Dream(压缩矩阵DP)

    一.Description Squares and rectangles fascinated the famous Dutch painter Piet Mondriaan. One night, ...

  7. Python-Redis的List操作

    Redis列表是简单的字符串列表,一个列表可以包含超过40亿个元素 lpush(name,values):在name对应的list中添加元素,每个新的元素都添加到列表的最左边 rpush(name, ...

  8. 在python3.6下 发明一个类似python3.7 dataclass数据类,不用在 __init__中self.xx

    虽然我用3.6,但我在2.7转3.6时候,把3.3 3.4 3.5 3.6的变化都看了一次,虽然已经忘了哪些变化.同时也关注3.7 3.8的变化,3.7中就有1个数据类印象深刻,因为之前在定义这种类时 ...

  9. python version 2.7 required,which was not found in

    python version 2.7 required,which was not found in 出现上面这种情况的原因我推测有两种: 1.NumPy和SciPy官方网站上只提供了32bit的文件 ...

  10. <正则吃饺子> :关于Java的native方法(转)

    感谢作者的分享,原文地址:http://blog.csdn.net/wike163/article/details/6635321 一. 什么是Native Method   简单地讲,一个Nativ ...