- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我有一个由多个 jar 组成的项目,并通过 war 来制造耳朵。我在快照中构建所有内容并且效果很好。然后我为每个项目发布了一个版本,发现 jars 和 war 的大小与快照的略有不同。
逐个文件比较发现.class文件都在,只是稍微大一点或大一点,一般不超过40字节。
我在 Maven 中使用此标记强制编译使用 java 1.5:
<build>
<pluginManagement>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>2.0.2</version>
<configuration>
<source>1.5</source>
<target>1.5</target>
</configuration>
我将这个标签用于发布插件:
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-release-plugin</artifactId>
<version>2.0</version>
<configuration>
<releaseProfiles>release</releaseProfiles>
<goals>deploy</goals>
</configuration>
</plugin>
可能是发布插件在 1.6 或其他版本中编译,解释类大小差异?如果是这样,我可以在 1.5 中编译发布插件吗?
感谢您的输入。
最佳答案
---剧透警告---
简短的回答是,为了将源代码编译为旧版本,您需要同时提供 -source
选项以及 -bootclasspath
.参见 this article .如果你想将源代码编译到更新的版本,你需要设置 <source>
, <target>
, <compilerVersion>
, <fork>
, 和 <executable>
在编译器插件上,和设置<jvm>
在 surefire 插件上...
现在讲故事......
我遇到了同样的问题。事实证明,编译以前的版本可能不像设置<source>
那么容易。和 <target>
.我的具体情况是我有一个 Java 1.7 JDK,我的类与 1.7 不兼容(他们向我正在实现的接口(interface)添加了一个新方法)。当我试图编译它时,编译器给我一条错误消息,指出我没有实现接口(interface)方法。无论如何,我尝试设置编译器插件:
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>2.3.2</version>
<configuration>
<source>1.6</source>
<target>1.6</target>
<encoding>UTF-8</encoding>
</configuration>
</plugin>
但是当我运行构建时,我得到了同样的错误。所以我在调试中运行了 maven 并看到了这个:
[INFO] [DEBUG] Command line options:
[INFO] [DEBUG] -d C:\... -nowarn -target 1.6 -source 1.6 -encoding UTF-8
请注意,为简洁起见,将 ... 放在实际参数的位置
在输出中。以-d
开头的消息是实际的完整编译参数列表。所以,如果你删除 -nowarn
标记并在 javac
之后粘贴其余部分在命令行上,您可以看到编译器的实际输出:
javac -d C:\... -target 1.6 -source 1.6 -encoding UTF-8
warning: [options] bootstrap class path not set in conjunction with -source 1.6
这会打印出方便的警告 bootstrap 类路径未与 -source 1.6 一起设置。在谷歌上搜索一下 this article其中指出:
To use javac from JDK N to cross-compiler to an older platform version, the correct practice is to:
- Use the older -source setting.
- Set the bootclasspath to compile against the rt.jar (or equivalent) for the older platform.
If the second step is not taken, javac will dutifully use the old language rules combined with new libraries, which can result in class files that do not work on the older platform since references to non-existent methods can get included.
现在引用 the maven documentation for the compiler plugin给出:
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>2.5.1</version>
<configuration>
<compilerArguments>
<verbose />
<bootclasspath>${java.home}\lib\rt.jar</bootclasspath>
</compilerArguments>
</configuration>
</plugin>
然后您可以将其与您之前的配置相结合以获得:
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>2.3.2</version>
<configuration>
<source>1.6</source>
<target>1.6</target>
<encoding>UTF-8</encoding>
<bootclasspath>${java.home}\lib\rt.jar</bootclasspath>
</configuration>
</plugin>
现在你只需要制作 ${java.home}
您的 mvn 可用的变量(通过 -D 系统属性,或通过普通的旧环境变量,或者您可以非常喜欢并将其填充到用户设置中的 Java 6 配置文件中)。
现在只需运行您的构建,然后去喝杯冰镇啤酒,而它会发出咕噜咕噜的声音...
---- 编辑----
最后一件事...总是需要在您的引导类路径中包含 rt.jar,但是,我发现根据具体情况可能需要更多。我必须包含 jce.jar(与 rt.jar 在同一目录中),因为我的应用程序正在执行加密工作。
---- 编辑 2 ----
对于笑容,我尝试了另一个方向。我没有使用针对 Java 6 编译的 Java 7 运行 Maven,而是使用针对 Java 7 编译的 Java 6 运行 Maven。第一次尝试非常简单:
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>2.5.1</version>
<configuration>
<source>1.7</source>
<target>1.7</target>
<fork>true</fork>
<verbose>true</verbose>
<compilerVersion>1.7</compilerVersion>
<executable>${JAVA_7_HOME}/bin/javac</executable>
<encoding>UTF-8</encoding>
</configuration>
</plugin>
基本上,我设置了我的 <source>
和 <target>
到 1.7,但这显然是不够的,因为 6 无法编译 7 代码。所以回到编译器插件,实际上有an example page描述需要做什么。即,您需要 <fork>
使用 java 7 关闭一个新进程 <executable>
.所以现在我想我已经准备好了。是时候启动构建了...
C:\Projects\my-project>mvn package
...
Caused by: java.lang.UnsupportedClassVersionError: mypackage.StupidTest : Unsup
ported major.minor version 51.0
...
[INFO] ------------------------------------------------------------------------
[INFO] BUILD FAILURE
[INFO] ------------------------------------------------------------------------
UnsupportedClassVersionError 到底是什么?仔细观察会告诉我们失败的是 maven-surefire-plugin。所以我只尝试 mvn compile
果然我获得了成功,因为 surefire 插件从未启动过。所以我跑 mvn -X package
并注意这个 gem :
Forking command line: cmd.exe /X /C ""C:\Program Files\Java\jdk1.6.0_29\jre\bin\
java" -jar C:\Projects\my-project\target\surefire\surefirebooter2373372991878002
398.jar C:\Projects\my-project\target\surefire\surefire1861974777102399530tmp C:
\Projects\my-project\target\surefire\surefire4120025668267754796tmp"
好的,所以它运行的是 java 6。为什么? surefire 的文档给出了这个:
jvm:
Option to specify the jvm (or path to the java executable) to use with the forking
options. For the default, the jvm will be a new instance of the same VM as the one
used to run Maven. JVM settings are not inherited from MAVEN_OPTS.
由于我们使用 Java 6 VM 运行 mvn,因此它 fork 了一个 Java 6 VM 用于单元测试。所以适本地设置这个选项:
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-surefire-plugin</artifactId>
<version>2.12</version>
<configuration>
<jvm>${JAVA_7_HOME}/bin/java</jvm>
</configuration>
</plugin>
然后启动构建...
[INFO] ------------------------------------------------------------------------
[INFO] BUILD SUCCESS
[INFO] ------------------------------------------------------------------------
关于java - Maven 发布插件 : specify java compiler version,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3638399/
我在互联网上搜索了很多小时,但没有找到满意的结果,所以 -VSTO Addin 和 COM Addin(我们作为类库项目制作并使用 Excel 对象)之间有什么区别?VSTO 项目是否有任何限制,例如
我在互联网上搜索了很多小时,但没有找到满意的结果,所以 -VSTO Addin 和 COM Addin(我们作为类库项目制作并使用 Excel 对象)之间有什么区别?VSTO 项目是否有任何限制,例如
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于 Stack Overflow 来说是偏离主题的,
我正在寻找有关如何构建可扩展 WCF 服务器(具有动态加载的服务)的建议,最好使用 System.Addins 或 MEF。 服务器应托管实现最小“插件”API(StartService/StopSe
有没有一种方法可以使用加载浏览器扩展/插件/插件的 headless 浏览器(即 PhantomJS、Selenium)来运行自动测试? 更具体地说,我想模拟广告拦截器(如 Ghostery、ad-b
我是 gradle 的新手,我使用 artifactory 作为我的 repo 服务器。我在网上查看了如何将我的项目发布到我的 repo 服务器,发现我可以使用 maven-publish 或使用 a
我想禁用某些状态的点击/事件,并仅使少数状态可点击。我通读了http://newsignature.github.io/us-map/处的文档,并且找不到与此问题相关的任何内容。 最佳答案 http:
据我了解,在Intellij中使用idea插件打开Maven构建的项目并不是最好的方法,即调用: mvn idea:idea 但是直接打开pom文件(Intellij有默认的Maven插件);同样的事
使用Artifactory plugin对于 Jenkins pipeline 来说是一种幸福,只要遵循文档就可以了。但后来我介绍了Maven Flatten plugin解析父模块和子模块 mvn
我已经安装了Elasticsearch版本1.7.1。一切正常。我也安装了 JDBC 驱动程序。检查下面我的插件文件夹 目录E:\Xampp\htdocs\my-elastic\elasticsear
在我使用 webpack common chunks 插件创建包含第三方库(如 angular、react、lodash 等)的 vendor 包之前,但后来我知道了 webpack dll
我们正在尝试使用(Jenkins、sonar、eclipse ...)安装 CI 平台。 为了让每个开发人员都可以在提交之前对他的代码进行分析,我想知道两种选择: 使用 Sonar 插件运行本地分析。
我知道这是一个比较特殊的问题。尽管如此,也许有些人知道这一点: 我想在 Eclipse 中使用 Maven 编译 Hector=> 分支:0.7.0 和标签:hector-0.7.0-29(https
我卡住了。我一直在尝试寻找或自己创建一个简单的准系统示例,说明如何为 VS 2010 Express 创建 Outlook 插件。我知道这在 VS 2010 Pro 中更简单,但是,在快速版本中真的不
我有以下排除过滤器来忽略所有 R 文件类: findbugs-exclude-filter.xml 当我将它用于 FindBugs-IDEA 插件时,它可以
我刚开始玩 CakePHP,我发现了 Wildflower CMS .我喜欢这个想法,并打算开始修补它。不过,我有一个问题。 在自述文件中,我发现了以下内容:“Wildflower 不是也不会是 Ca
虽然现在大部分情况都是使用n-api来编写插件,但是底层毕竟是v8(和libuv),使用v8编写简单的插件,同时熟悉v8的使用。 本文介绍在写c++插件时,简单又常用的写法,其实本质上,写插件
本篇是 Python 系列教程第 3 篇,更多内容敬请访问我的 Python 合集 Visual Studio Code的安装非常简单,就不放这里增加文章篇幅了。 相比PyCharm,V
Maven – 插件 什么是 Maven 插件? Maven 实际上是一个依赖插件执行的框架,每个任务实际上是由插件完成。Maven 插件通常被用来: 创建 jar 文件 创建 war
我正在编写一个插件来添加带有标签 [deposit_page] 的页面;该标记应替换为一些 PHP 代码。 这就是我所拥有的,但它不起作用。有什么我遗漏或做错了什么吗? function deposi
我是一名优秀的程序员,十分优秀!