Maven基础-pom.xml中配置打包的入口程序和第三方依赖jar包(包含自己jar包)

1.说明

本文的打包操作适用于 普通的java项目
本文介绍的 maven 的打包方式是把java项目的第三方依赖包与主程序独立出来,即目标jar包与依赖包目录同级。
本文介绍的项目中包含自己写的本地的第三方依赖包。

2.具体的操作

2.1 项目结构介绍

一个标准的maven项目: 目录结构完全符合maven规范
【注意】:自己的第三方依赖包的名称中一定要包含一个 版本号的信息,这样在pom.xml中配置时可以使用到。 如 : java-utile-from-northcastle-1.0.jar 中的 -1.0

helloworld-maven-java
    | -- src
    	| -- main
    		| -- java
    			| -- com.northcastle
    				| -- App.java : 主类
    		| -- resources
    			| -- libs
    				| -- java-utile-from-northcastle-1.0.jar
    	| -- test
    		| -- java
    			| -- com.northcastle
    				| -- AppTest.java
    		| -- resources
    |-- pom.xml

App.java 的文件内容:

package com.northcastle;

import com.alibaba.fastjson.JSONObject;
import com.northcastle.utile.a.UtileA;
import com.northcastle.utile.b.UtileB;

/**
 * Hello world!
 *
 */
public class App {
    public static void main( String[] args ){

        System.out.println("=== App run begin ===");
        System.out.println( "Hello World!" );
        System.out.println( "欢迎使用maven进行打包工作" );
        JSONObject jsonObject = new JSONObject();
        jsonObject.put("name","northcastle");
        System.out.println("jsonObject is  : "+jsonObject);
        UtileA.sayHelloA(); // 使用到了自己的第三方的依赖包
        UtileB.sayHelloB(); // 使用到了自己的第三方的依赖包
        System.out.println("=== App run end ===");
    }
}

2.2 pom.xml文件内容(核心)

pom.xml 中主要 包含了引入的第三方的依赖包(包含自己写的第三方依赖包)、以及跳过测试的配置、打包的配置。
具体内容如下:

<?xml version="1.0" encoding="UTF-8"?>

<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.northcastle</groupId>
<artifactId>helloworld-maven-java</artifactId>
<version>1.0-SNAPSHOT</version>

  <!--设置打包的类型为 jar 包-->
  <packaging>jar</packaging>

<!--  自定义的属性设置,可以自己进行配置和修改-->
<properties>
  <!--  maven 编译代码使用的jdk版本  -->
  <maven.compiler.source>1.8</maven.compiler.source>
  <!--  maven 执行代码使用的jdk版本  -->
  <maven.compiler.target>1.8</maven.compiler.target>
  <!--  maven 编译使用的编码  -->
  <maven.compiler.encoding>UTF-8</maven.compiler.encoding>
  <!--  maven 进行项目构建使用的编码,避免中文乱码  -->
  <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
  <!--  maven 生成项目报告使用的编码  -->
  <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>

</properties>

<!--  依赖中默认带有一个 junit 单元测试-->
<dependencies>

  <!-- https://mvnrepository.com/artifact/com.alibaba/fastjson -->
  <dependency>
    <groupId>com.alibaba</groupId>
    <artifactId>fastjson</artifactId>
    <version>1.2.75</version>
  </dependency>

  <dependency>
    <groupId>junit</groupId>
    <artifactId>junit</artifactId>
    <version>4.11</version>
    <scope>test</scope>
  </dependency>

  <!-- 引入自己写的jar包 
	groupId : 可以随便写一个
	artifactId : 建议使用自己的jar包的名称(不带版本号)
	version : 使用jar包名称中的版本号
	scope : 一定是 system
	systemPath : 指定自己的依赖包
  -->
  <dependency>
    <groupId>com.northcastle</groupId>
    <artifactId>java-utile-from-northcastle</artifactId>
    <version>1.0</version>
    <scope>system</scope>
    <systemPath>${project.basedir}/src/main/resources/libs/java-utile-from-northcastle-1.0.jar</systemPath>
  </dependency>

</dependencies>

<build>
  <!-- 指定最后构建打包成功的压缩包的名字 -->
  <finalName>helloworld-maven-java</finalName>

  <plugins>
    <!-- 1.maven 打包时跳过测试 -->
    <plugin>
      <groupId>org.apache.maven.plugins</groupId>
      <artifactId>maven-surefire-plugin</artifactId> <!-- 测试使用到的插件 -->
      <configuration>
        <skip>true</skip><!-- 声明跳过测试 -->
      </configuration>
    </plugin>

    <!-- 2.1 maven 打包时指定main方法 -->
    <plugin>
      <groupId>org.apache.maven.plugins</groupId>
      <artifactId>maven-jar-plugin</artifactId>
      <configuration>
        <classesDirectory>target/classes</classesDirectory>
        <archive>
          <manifest>
            <mainClass>com.northcastle.App</mainClass>
            <useUniqueVersions>false</useUniqueVersions>
            <addClasspath>true</addClasspath>
            <classpathPrefix>libs/</classpathPrefix>
          </manifest>
          <manifestEntries>
            <Class-Path>.</Class-Path>
            <!-- 手动把自己的依赖包添加到 MANIFEST.MF 清单文件中去!!! -->
            <Class-Path>libs/java-utile-from-northcastle-1.0.jar</Class-Path>
          </manifestEntries>
        </archive>
      </configuration>
    </plugin>
    <!--  2.2 maven 打包时处理依赖的第三方jar包,解决 运行时 ClassNotFoundException 的异常  -->
    <plugin>
      <groupId>org.apache.maven.plugins</groupId>
      <artifactId>maven-dependency-plugin</artifactId>
      <executions>
        <execution>
          <id>copy-dependencies</id>
          <phase>package</phase>
          <goals>
            <goal>copy-dependencies</goal>
          </goals>
          <configuration>
            <type>jar</type>
            <includeTypes>jar</includeTypes>
            <outputDirectory>
              ${project.build.directory}/libs
            </outputDirectory>
          </configuration>
        </execution>
      </executions>
    </plugin>
  </plugins>
</build>


</project>

2.2.1 pom.xml 中表示指定程序入口类的配置

这一块是配置的核心:
最特殊的是 :配置中的这一句话 :
当有多个本地的jar包时,用空格进行分开。
Class-Path标签只能有一个

 <manifestEntries>
 
        <!-- 手动把自己的依赖包添加到 MANIFEST.MF 清单文件中去!!! -->
       <Class-Path> . libs/java-utile-from-northcastle-1.0.jar xxxxx.jar</Class-Path>
 </manifestEntries>
  <!-- 2.1 maven 打包时指定main方法 -->
    <plugin>
      <groupId>org.apache.maven.plugins</groupId>
      <artifactId>maven-jar-plugin</artifactId>
      <configuration>
        <classesDirectory>target/classes</classesDirectory>
        <archive>
         <!-- manifest 标签表示 jar包内的 MANIFEST.MF 清单配置文件的内容 -->
          <manifest>
            <!-- 1.mainClass 标签指定程序的入口类 -->
            <mainClass>com.northcastle.App</mainClass>
            <useUniqueVersions>false</useUniqueVersions>
            <addClasspath>true</addClasspath>
             <!-- 2.classpathPerfix 标签 表示指定第三方依赖的目录名,和目标jar包同级 -->
            <classpathPrefix>libs/</classpathPrefix>
          </manifest>
          <manifestEntries>
             <!-- 手动把自己的依赖包添加到 MANIFEST.MF 清单文件中去!!! -->
            <Class-Path>. libs/java-utile-from-northcastle-1.0.jar</Class-Path>
          </manifestEntries>
        </archive>
      </configuration>
    </plugin>

2.2.2 pom.xml 中表示第三方依赖的配置

这一块是配置的核心 : 如果不理解,直接抄上就行

 <!--  2.2 maven 打包时处理依赖的第三方jar包,解决 运行时 ClassNotFoundException 的异常  -->
    <plugin>
      <groupId>org.apache.maven.plugins</groupId>
      <artifactId>maven-dependency-plugin</artifactId>
      <executions>
        <execution>
          <id>copy-dependencies</id>
          <phase>package</phase>
          <goals>
            <goal>copy-dependencies</goal>
          </goals>
          <configuration>
            <type>jar</type>
            <includeTypes>jar</includeTypes>
            <outputDirectory>
              ${project.build.directory}/libs
            </outputDirectory>
          </configuration>
        </execution>
      </executions>
    </plugin>

2.3 执行打包命令

在 pom.xml 文件所在的目录下执行打包命令 : mvn clean package

在这里插入图片描述

在这里插入图片描述

2.4 查看打包后target目录

根据我们的pom.xml 中的配置,打包成功后:
1.会在 target目录 下生成一个 libs的目录来存放我们的第三方的依赖包;
2.会在 target目录 下生成我们的目标jar包

在这里插入图片描述
在这里插入图片描述

2.5 运行jar包,检查效果

使用java -jar xxx.jar 命令,运行程序

在这里插入图片描述
》 ps : 如果各位coder出现打包成功,但在运行时报 ClassNotFoundException的异常,请仔细阅读本篇文章的2.2节,会给你启发的。

3.完成

Congratulations!
You are one step closer to success!

### 回答1: 在Mavenpom.xml文件添加本地的jar包依赖有两种方法: 1.使用系统范围依赖pom.xml的dependencies添加以下配置: ``` <dependencies> <dependency> <groupId>local</groupId> <artifactId>local-jar</artifactId> <version>1.0</version> <scope>system</scope> <systemPath>${project.basedir}/lib/local-jar-1.0.jar</systemPath> </dependency> </dependencies> ``` 其,groupId、artifactId和version可以任意指定,systemPath指定了本地jar包的路径。使用这种方法可能会导致项目的可移植性受到影响。 2.将jar包安装到本地仓库 在命令行执行以下命令将jar包安装到本地仓库: ``` mvn install:install-file -Dfile=D:\local-jar-1.0.jar -DgroupId=local -DartifactId=local-jar -Dversion=1.0 -Dpackaging=jar ``` 在pom.xml的dependencies添加以下配置: ``` <dependencies> <dependency> <groupId>local</groupId> <artifactId>local-jar</artifactId> <version>1.0</version> </dependency> </dependencies> ``` 打包方法: 在命令行执行以下命令进行打包: ``` mvn package ``` 执行该命令会在项目的target目录下生成一个jar包,其包含了项目的所有依赖。可以使用以下命令运行jar包: ``` java -jar target/my-project.jar ``` ### 回答2: Maven是一个优秀的项目构建工具,但是在实际开发,很多项目可能需要依赖一些本地的jar包,因为这些jar包可能没有被上传到Maven央仓库或者公司内部的私有仓库。那么在Maven如何添加本地jar包依赖呢? 一、将本地jar包安装到Maven本地仓库 在添加本地jar包前,需要先将其安装到Maven本地仓库。可以使用以下命令在本地仓库安装jar包: ``` mvn install:install-file -Dfile=path-to-your-jar -DgroupId=your.group.id -DartifactId=your-artifact-id -Dversion=your-version -Dpackaging=jar ``` 其,path-to-your-jar为本地jar包的绝对路径,your.group.id为你的项目组id,your.artifact.id为你的项目id,your-version为jar包的版本号。请根据实际情况修改。 这条命令将会在Maven本地仓库安装该jar包,并且可以通过groupId、artifactId和version来引用该jar包。 二、在pom.xml添加本地jar包依赖 添加本地jar包之后,就可以在项目的pom.xml添加依赖了。在dependencies标签添加以下代码: ```xml <dependency> <groupId>your.group.id</groupId> <artifactId>your-artifact-id</artifactId> <version>your-version</version> <scope>system</scope> <systemPath>${basedir}/path-to-your-jar</systemPath> </dependency> ``` 其,your.group.id、your.artifact.id和your-version与上面安装jar包时保持一致,scope为system,systemPath为本地jar包的路径,通常使用${basedir}占位符表示项目根目录。 三、使用Maven打包 在添加本地jar包依赖之后,就可以使用Maven进行项目打包了。常见的打包方式有两种,分别是打JAR包和打WAR包。 1. 打JAR包JAR包的目的是将Java项目打包成一个可执行的jar文件,可以通过以下命令打包: ``` mvn package ``` 执行该命令将会在target目录下生成一个以项目名称为命名的jar包。 2. 打WAR包 打WAR包的目的是将Web项目打包成一个可部署的war文件,可以通过以下命令打包: ``` mvn package ``` 执行该命令将会在target目录下生成一个以项目名称为命名的war包。 总的来说,将本地jar包添加为Maven依赖和使用Maven进行项目打包是比较常见的开发操作,掌握这些技能对于提高开发效率具有重要作用。 ### 回答3: MavenJava项目管理工具,可以帮助开发人员自动构建项目,以及管理项目依赖库。在项目,有时需要添加本地jar包作为依赖,这就需要在项目pom.xml文件做出相应的修改。 添加本地jar包依赖: 1. 将需要添加的本地jar包放到项目一个指定的目录下,可以是项目根目录下的lib目录等。 2. 在pom.xml文件的<dependency>标签,添加如下内容: ```xml <dependency> <groupId>local</groupId> <artifactId>jar包名称(不包含后缀名)</artifactId> <version>1.0</version>(可选) <scope>system</scope> <systemPath>${basedir}/lib/本地jar包全名(包含后缀名)</systemPath> </dependency> ``` 这里,groupId设置为“local”,artifactId为本地jar包的名称(不包含后缀名),version版本号可选,scope设置为“system”,systemPath指定本地jar包的具体路径。${basedir}表示当前项目的根目录。 3. 保存pom.xml文件,重新构建项目,就可以成功添加本地jar包依赖了。 打包方法: 1. 在项目根目录下运行以下命令,生成jar包: ``` mvn clean package ``` 2. 如果需要将项目打成war包,可以修改pom.xml文件,在<packaging>标签将“jar”修改为“war”,然后重新构建项目。打出来的war包会自动发布到Tomcat等服务器。 这样,就可以通过Maven将项目打包jar或war包了。同时,Maven也提供了很多其他的构建、依赖管理等功能,可以大大提高开发效率。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值