Maven可执行jar与外部路径上的库

jav*_*ber 5 jar maven

我的jar没有运行,我可以告诉它尝试运行,因为log4j文件管理创建日志文件夹,但没有任何反应,日志是空白的.

我的问题是我将jar文件放在名为bin的文件夹中,并将库放在名为lib的文件夹中

我在嘲笑这个:

<plugin>
    <groupId>org.apache.maven.plugins</groupId>
    <artifactId>maven-jar-plugin</artifactId>
    <configuration>
    <outputDirectory>${staging.dir}/bin</outputDirectory>
      <archive>
        <manifest>
          <addDefaultImplementationEntries>true</addDefaultImplementationEntries>
          <addClasspath>true</addClasspath>
          <mainClass>com.Main</mainClass>
          <classpathPrefix>../lib/</classpathPrefix>
        </manifest>
      </archive>
    </configuration>
  </plugin>
Run Code Online (Sandbox Code Playgroud)

<plugin>
    <artifactId>maven-dependency-plugin</artifactId>
    <executions>
        <execution>
            <phase>package</phase>
            <goals>
                <goal>copy-dependencies</goal>
            </goals>
            <configuration>
                <outputDirectory>${staging.dir}/lib</outputDirectory>
            </configuration>
        </execution>
    </executions>
</plugin>
Run Code Online (Sandbox Code Playgroud)

我也尝试过使用maven-assembly-plugin,但它包装了jar上的所有东西,我真的需要有文件夹bin和lib

我需要设置什么才能使其正常工作?

编辑:META-INF文件

Manifest-Version: 1.0
Archiver-Version: Plexus Archiver
Created-By: Apache Maven
Built-By: me
Build-Jdk: 1.6.0_26
Main-Class: com.Main
Class-Path: ../lib/ojdbc6-11.2.0.jar ../lib/sqljdbc4-4.2.0.jar ../lib/
mysql-connector-java-5.1.17.jar ../lib/hibernate-core-3.6.5.Final.jar
../lib/antlr-2.7.6.jar ../lib/commons-collections-3.1.jar ../lib/dom
4j-1.6.1.jar ../lib/hibernate-commons-annotations-3.2.0.Final.jar ../
lib/hibernate-jpa-2.0-api-1.0.0.Final.jar ../lib/jta-1.1.jar ../lib/s
lf4j-api-1.6.1.jar ../lib/hibernate-entitymanager-3.6.5.Final.jar ../
lib/cglib-2.2.jar ../lib/asm-3.1.jar ../lib/javassist-3.12.0.GA.jar .
./lib/slf4j-log4j12-1.6.1.jar ../lib/log4j-1.2.16.jar ../lib/commons-
codec-1.5.jar ../lib/lablib-checkboxtree-3.3-20110114.141734-3.jar
Run Code Online (Sandbox Code Playgroud)

原来META-INF文件不正确.原因是maven-archiver-plugin将时间戳重命名为SNAPSHOT库作为默认行为

根据Maven Archiver doc的指示覆盖使用它:

<plugins>
  <plugin>
     <artifactId>maven-war-plugin</artifactId>
     <configuration>
       <archive>
         <manifest>
           <addDefaultImplementationEntries>true</addDefaultImplementationEntries>
          <addClasspath>true</addClasspath>
          <useUniqueVersions>false</useUniqueVersions>
          <mainClass>com.Main</mainClass>
          <classpathPrefix>../lib/</classpathPrefix>
         </manifest>
       </archive>
     </configuration>
  </plugin>
</plugins>
Run Code Online (Sandbox Code Playgroud)

除此之外,我希望人们在一开始就找到有用的maven代码,因为它确实有效,只要注意项目中的SNAPSHOTS

icy*_*com 3

以上一切似乎都OK。以下是您可能想要尝试/确认/回答的一些事情/问题:

  • 你是从命令行运行这个吗?即使用java -jar <your.jar>或启动它,例如通过双击文件等?如果没有,请尝试从命令行运行它,看看会发生什么
  • 尝试使用mvn exec:java看看是否会定期启动您的应用程序(maven-)。如果您不熟悉 exec 插件,请参阅http://mojo.codehaus.org/exec-maven-plugin/usage.html
  • 您可以使用常规 JavaSystem.out.println而不是日志记录来确认它实际启动吗?日志大小为零可能是日志记录配置问题
  • 我看到你上面有一些数据库库。您能否在基本初始化周围放置一些 println (或更好的日志记录,但只有在您确认日志记录确实有效之后)语句,以确认您不只是停滞在那里(前提是正在发生的情况 - 您没有提到任何异常或其他问题具体来说)

很大程度上取决于实际的应用程序代码,但希望上面的一些内容可以帮助您查明问题。

顺便说一句,你的主课真的是吗com.Main?如果是,我可以建议将其更改为更合适的内容 - 例如com.yourdomain.yourapp.Main或类似的内容。这并不是说这会改变上面的结果,只是一个风格上的评论。