2017-02-10 92 views
0

我想运行官方耶拿文件的第一个例子。一个简单的耶拿例子不工作

这里是我得到的错误,当我运行命令 “Java的罐子目标/我-APP-1.0-SNAPSHOT-JAR-与-dependencies.jar”:

SLF4J: Failed to load class "org.slf4j.impl.StaticLoggerBinder". 
SLF4J: Defaulting to no-operation (NOP) logger implementation 
SLF4J: See http://www.slf4j.org/codes.html#StaticLoggerBinder for further details. 
Exception in thread "main" java.lang.ExceptionInInitializerError 
    at com.mycompany.app.RdfWriter.main(RdfWriter.java:13) 
Caused by: java.lang.NullPointerException 
    at org.apache.jena.tdb.sys.EnvTDB.processGlobalSystemProperties(EnvTDB.java:33) 
    at org.apache.jena.tdb.TDB.init(TDB.java:248) 
    at org.apache.jena.tdb.sys.InitTDB.start(InitTDB.java:29) 
    at org.apache.jena.system.JenaSystem.lambda$init$2(JenaSystem.java:119) 
    at java.util.ArrayList.forEach(ArrayList.java:1249) 
    at org.apache.jena.system.JenaSystem.forEach(JenaSystem.java:194) 
    at org.apache.jena.system.JenaSystem.forEach(JenaSystem.java:171) 
    at org.apache.jena.system.JenaSystem.init(JenaSystem.java:117) 
    at org.apache.jena.rdf.model.ModelFactory.<clinit>(ModelFactory.java:49) 
    ... 1 more 

这里是我的POM文件:

<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/maven-v4_0_0.xsd"> 
    <modelVersion>4.0.0</modelVersion> 
    <groupId>com.mycompany.app</groupId> 
    <artifactId>my-app</artifactId> 
    <packaging>jar</packaging> 
    <version>1.0-SNAPSHOT</version> 
    <name>my-app</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>3.8.1</version> 
     <scope>test</scope> 
    </dependency> 
    <dependency> 
     <groupId>org.apache.jena</groupId> 
     <artifactId>apache-jena-libs</artifactId> 
     <version>3.1.1</version> 
     <type>pom</type> 
    </dependency> 
    <dependency> 
     <groupId>org.apache.logging.log4j</groupId> 
     <artifactId>log4j-core</artifactId> 
     <version>2.7</version> 
    </dependency> 
    </dependencies> 


    <build> 
     <plugins> 
     <plugin> 
      <artifactId>maven-assembly-plugin</artifactId> 
      <configuration> 
      <archive> 
       <manifest> 
       <mainClass>com.mycompany.app.RdfWriter</mainClass> 
       </manifest> 
      </archive> 
      <descriptorRefs> 
       <descriptorRef>jar-with-dependencies</descriptorRef> 
      </descriptorRefs> 
      </configuration> 
     </plugin> 
     </plugins> 
    </build> 

</project> 

这里是唯一的文件,我到目前为止有:

package com.mycompany.app; 

import org.apache.jena.rdf.model.*; 
import org.apache.jena.vocabulary.*; 

public class RdfWriter { 

    static String personURI = "http://somewhere/JohnSmith"; 
    static String fullName  = "John Smith"; 

    public static void main(String[] args) { 
     // create an empty model 
     Model model = ModelFactory.createDefaultModel(); 
     // create the resource 
     Resource johnSmith = model.createResource(personURI); 
     // add the property 
     johnSmith.addProperty(VCARD.FN, fullName); 
     System.out.println("this is rdf writer"); 
    } 

} 

我只是想上手,所以如果有WA如果问题比较简单,请修复该问题,甚至不使用maven,请告诉我。

我添加了一个新的依赖的依赖在我的POM文件塔希尔后面提到的是,在这样回答:

<dependency> 
    <groupId>org.slf4j</groupId> 
    <artifactId>slf4j-simple</artifactId> 
    <version>1.6.2</version> 
</dependency> 

,现在我收到此错误:

Exception in thread "main" java.lang.ExceptionInInitializerError 
    at com.mycompany.app.RdfWriter.main(RdfWriter.java:14) 
Caused by: java.lang.NullPointerException 
    at org.apache.jena.tdb.sys.EnvTDB.processGlobalSystemProperties(EnvTDB.java:33) 
    at org.apache.jena.tdb.TDB.init(TDB.java:248) 
    at org.apache.jena.tdb.sys.InitTDB.start(InitTDB.java:29) 
    at org.apache.jena.system.JenaSystem.lambda$init$2(JenaSystem.java:119) 
    at java.util.ArrayList.forEach(ArrayList.java:1249) 
    at org.apache.jena.system.JenaSystem.forEach(JenaSystem.java:194) 
    at org.apache.jena.system.JenaSystem.forEach(JenaSystem.java:171) 
    at org.apache.jena.system.JenaSystem.init(JenaSystem.java:117) 
    at org.apache.jena.rdf.model.ModelFactory.<clinit>(ModelFactory.java:49) 
    ... 1 more 

感谢

+0

提出和回答耶拿用户列表:https://lists.apache.org/thread.html/[email protected]%3Cusers.jena.apache.org%3E – AndyS

+0

@AndyS,我添加了一个链接,日食选项,你提到的答案是这样的:我不知道如何将它们与汇编插件结合起来。希望有人知道这里。 –

回答

0

您需要在您的类路径中添加以下jar文件:
slf4j-simple-1.6.1.jar

只需添加此依赖关系,看看它是否会解决您的problrm?

<!-- https://mvnrepository.com/artifact/org.slf4j/slf4j-simple --> 
<dependency> 
<groupId>org.slf4j</groupId> 
<artifactId>slf4j-simple</artifactId> 
<version>1.6.1</version> 

+0

我将它添加为maven依赖项,现在我得到一个新的错误。 –

+0

更新您的问题:说您添加了所需的依赖关系,并更新您的问题与新错误@KarimMtl –

+0

我做到了这一点之前,添加您以前的评论。 –

0

当您重新包装与装配插件瓶子,ServiceLoader文件得到了错位。 ServiceLoader是Jena用于跨罐提供初始化的标准Java功能。

你需要从所有的罐子被称为

META-INF/services/org.apache.jena.system.JenaSubsystemLifecycle 

结合文件(有几个这样的文件,不同的内容)。

如果您确实需要构建组合jar,而不是使用“mvn exec:exec”,那么请使用带有<transformer implementation= "org.apache.maven.plugins.shade.resource.ServicesResourceTransformer/>的阴影插件。

+0

我会试试这个,让你知道 –