当我在eclipse中将它作为java应用程序运行时,我的代码工作正常,但是当我使用maven-exec插件运行maven install时,它失败了。我知道它失败是因为它找不到配置文件,但是怎么找呢?
如果我排除了maven-exec插件,它就会成功构建,我可以执行带有依赖项的jar文件。
public class App
{
public static void main( String[] args )
{
System.out.println( "... starting DomParser" );
System.out.println( "... inside app" );
DOMParser.loadXML("/config.xml");
System.out.println( "... ending DomParser" );
}
}
下面是简化的DomParser类
static SAXBuilder builder = new SAXBuilder();
static Document doc;
public static void loadXML(String path) {
java.net.URL url = DOMParser.class.getClass().getResource(path);
doc = builder.build(url);
root = doc.getRootElement();
}
这是绒球.xml
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.ericsson.ci.simnet</groupId>
<artifactId>domparser</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>jar</packaging>
<name>domparser</name>
<url>http://maven.apache.org</url>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
</properties>
<dependencies>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.0</version>
<scope>test</scope>
</dependency>
<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>1.2.14</version>
</dependency>
<dependency>
<groupId>org.jdom</groupId>
<artifactId>jdom2</artifactId>
<version>2.0.5</version>
</dependency>
</dependencies>
<build>
<!-- <finalName>${project.name}</finalName> -->
<plugins>
<!-- Tell maven to compile using Java 1.7 -->
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>3.1</version>
<configuration>
<source>1.6</source>
<target>1.6</target>
</configuration>
</plugin>
<plugin>
<groupId>org.codehaus.mojo</groupId>
<artifactId>exec-maven-plugin</artifactId>
<version>1.2.1</version>
<executions>
<execution>
<phase>test</phase>
<goals>
<goal>java</goal>
</goals>
<configuration>
<mainClass>com.x.ci.simnet.domparser.App</mainClass>
<arguments>
<argument></argument>
</arguments>
</configuration>
</execution>
</executions>
</plugin>
<!-- to bundle necessary classes of dependent JAR files -->
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-shade-plugin</artifactId>
<version>1.5</version>
<executions>
<execution>
<phase>package</phase>
<goals>
<goal>shade</goal>
</goals>
<configuration>
<transformers>
<transformer
implementation="org.apache.maven.plugins.shade.resource.ManifestResourceTransformer">
<mainClass>com.x.ci.simnet.domparser.App</mainClass>
</transformer>
</transformers>
<!--<shadedArtifactAttached>true</shadedArtifactAttached> -->
</configuration>
</execution>
</executions>
</plugin>
</plugins>
</build>
</project>
错误在这里:
[ERROR] Failed to execute goal org.codehaus.mojo:exec-maven-plugin:1.2.1:java (default) on project domparser: An exception occured while executing the Java class. null: InvocationTargetException: NullPointerException -> [Help 1]
经过长时间的夜间工作,我找到了解决办法。感谢大家的帮助。
我替换了DomParser类代码,如下所示
import org.jdom2.input.SAXBuilder;
import org.jdom2.Document;
public class DOMParser {
static SAXBuilder builder = new SAXBuilder();
static Document doc;
...
...
public static void loadXML(String path) {
ClassLoader classLoader = Thread.currentThread().getContextClassLoader();
java.net.URL url = classLoader.getResource(path);
doc = builder.build(url);
root = doc.getRootElement();
}
所以,关键的技巧是使用下面的代码行。
ClassLoader classLoader = Thread.currentThread().getContextClassLoader();
这允许您通过以下方式运行应用程序
我希望这能帮助其他人将来遇到类似的问题。
更新:
忘了说我还稍微修改了App类代码。就一句台词。我传递一个没有正斜杠的文件,如下。
DOMParser.loadXML("config.xml");
为了提高我的代码质量,我决定尝试学习如何使用单元测试来测试我的代码,而不是使用最好的测试解决方案。 我决定使用composer为个人库安装PHPUnit,它允许我实现常见的数据库功能。起初,我没有PHPUnit的配置文件,当我运行以下命令时: 请注意,这是一个终端命令,因此我没有包括扩展。上面提到的GeneralStringFunctionsTest实际上是一个文件。 输出是我所期望的: 时间:3
我在我的windows机器上设置了Elk堆栈,其中包含以下内容: Elasticserach Logstash Kibana 我的logstash.conf 我的日志文件。日志(Apache日志) 当我运行logstash时。conf它在elasticsearch中创建以下索引: 上面的索引为空,无法从我的日志文件中获取任何数据。请帮忙?我对麋鹿很陌生。 当我使用以下方法查询索引logstash-
Maven项目标志错误:未能执行goal org.springframework.boot:spring-boot-maven-plugin:2.1.3。release:repackage(repackage)on project pet-clinic-data:repackage of goal org.springframework.boot:spring-boot-maven-plugin:
我是maven的新手,学习如何以及何时在插件中执行阶段/目标 假设我的pom中有以下代码片段 现在,如果我执行mvn安装,安装之前的modello的所有阶段(以及每个阶段对应的所有目标)都将执行。正当 但是,如果进行以下修改以引入特定目标,则只会执行一个目标,即java目标(因为它位于安装阶段之前的生成源代码阶段)。对吗?
我想使用新的log4j2-Java日志框架。一切正常,但我从一小时后就尝试加载一个自定义配置文件来配置日志记录(如日志级别)。 这是我的log4j2.xml: 我尝试了以下方法,但没有任何效果: 移动log4j2.xml文件,使其位于默认包中。 将log4j2.xml文件移动到项目中的任意位置 将log4j2.xml文件命名为log4j.xml 在项目中创建一个文件夹,将log4j2.xml文件放
问题 怎样读取普通.ini格式的配置文件? 解决方案 configparser 模块能被用来读取配置文件。例如,假设你有如下的配置文件: ; config.ini ; Sample configuration file [installation] library=%(prefix)s/lib include=%(prefix)s/include bin=%(prefix)s/bin prefi