![](/img/trans.png)
[英]maven-nar-plugin vs native-maven-plugin, which is better?
[英]Java JNI Maven native-maven-plugin - how to set shared library final name
我正在與JNI和Maven一起玩,以了解如何自動化構建過程。 在輸出文件名方面,我在Linux平台上遇到一些困難。 當我運行Maven構建時(下面是Linux平台的pom.xml),返回的共享庫文件名為jniExampleNative.so
。 如果嘗試使用它運行Java程序,則會得到java.lang.UnsatisfiedLinkError: no jniExampleNative in java.library.path
。 如果我將文件重命名為libjniExampleNative.so
它將起作用。
我想設置Maven,以便它自動使用工作文件名創建文件,但不知道如何。 我嘗試設置linkerFinalName
選項(在下面的pom.xml中有注釋),但是我得到The packaging for this project did not assign a file to the build artifact
。
我在哪里做錯事,如何設置輸出共享庫的名稱?
<project>
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>net.tricoder.jnitest</groupId>
<artifactId>nativeParent</artifactId>
<version>1.0-SNAPSHOT</version>
</parent>
<groupId>net.tricoder.jnitest</groupId>
<artifactId>jniExampleNative</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>JNI example native Linux</name>
<url>http://maven.apache.org</url>
<packaging>so</packaging>
<dependencies>
<dependency>
<groupId>net.tricoder.jnitest</groupId>
<artifactId>jniExampleJava</artifactId>
<version>1.0-SNAPSHOT</version>
<type>jar</type>
<scope>compile</scope>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<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>native-maven-plugin</artifactId>
<extensions>true</extensions>
<configuration>
<!-- trigger javah -->
<javahOS>linux</javahOS>
<compilerProvider>generic-classic</compilerProvider>
<compilerExecutable>gcc</compilerExecutable>
<linkerExecutable>gcc</linkerExecutable>
<sources>
<source>
<directory>../src/main/native</directory>
<fileNames>
<fileName>jni_example.c</fileName>
</fileNames>
</source>
</sources>
<compilerStartOptions>
<compilerStartOption>-fPIC</compilerStartOption>
</compilerStartOptions>
<linkerStartOptions>
<linkerStartOption>-shared</linkerStartOption>
</linkerStartOptions>
<!--linkerOutputDirectory>${project.build.directory}</linkerOutputDirectory>
<linkerFinalName>libjniExampleNative</linkerFinalName-->
</configuration>
<executions>
<execution>
<id>javah</id>
<phase>generate-sources</phase>
<configuration>
<javahOS>linux</javahOS>
<javahProvider>default</javahProvider>
<javahOutputDirectory>${project.build.directory}/custom-javah</javahOutputDirectory>
<workingDirectory>${basedir}</workingDirectory>
<javahOutputFileName>NativeStuff.h</javahOutputFileName>
<javahClassNames>
<javahClassName>net.tricoder.jnitest.NativeStuff</javahClassName>
</javahClassNames>
</configuration>
<goals>
<goal>javah</goal>
</goals>
</execution>
</executions>
</plugin>
</plugins>
</build>
</project>
<linkerFinalName>libjniExampleNative</linkerFinalName>
可以解決問題。 問題出在我正在運行mvn clean install -P linux
的生命周期中。 返回install
階段The packaging for this project did not assign a file to the build artifact
。
將其更改為mvn clean package -P linux
它可以正常工作。 現在,我將不得不弄清楚為什么install
與<linkerFinalName>libjniExampleNative</linkerFinalName>
發生沖突,因為只有在設置linkerFinalName
選項時才會出現錯誤。
查看源代碼 ,我發現native-maven-plugin將build.finalName
設置為<artifactId>
,並且忽略了原始的<finalName>
和<linkerFinalName>
因此,將<artifactId>
更改為所需的finalName
“解決”問題。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.