zoukankan      html  css  js  c++  java
  • MAVEN之pom文件的快速应用

    MAVEN依赖关系中Scope的作用
    Dependency Scope 在POM4中
    <dependency>中还引入了<scope>,它主要管理依赖的部署。
    目前依赖项的作用域<scope>可以使用5个值:
    在定义项目的依赖项的时候,我们可以通过scope来指定该依赖项的作用范围。
    
    scope的取值有
    
    compile:这是依赖项的默认作用范围,即当没有指定依赖项的scope时默认使用compile。compile范围内的
    依赖项在所有情况下都是有效的,包括运行、测试和编译时。
    
    runtime:表示该依赖项只有在运行时才是需要的,在编译的时候不需要。
    这种类型的依赖项将在运行和test的类路径下可以访问。
    
    test:表示该依赖项只对测试时有用,包括测试代码的编译和运行,对于正常的项目运行是没有影响的。
    
    provided:表示该依赖项将由JDK或者运行容器在运行时提供,也就是说由Maven提供的该依赖项我们只有在
    编译和测试时才会用到,而在运行时将由JDK或者运行容器提供。
    
    system:当scope为system时,表示该依赖项是我们自己提供的,不需要Maven到仓库里面去找。
    指定scope为system需要与另一个属性元素systemPath一起使用,它表示该依赖项在当前系统的位置,使用的是绝对路径。
    POM文件里面可以引用一些内置属性(Maven预定义可以直接使用)
    ${basedir} 项目根目录
    ${version} 表示项目版本;
    ${project.basedir} 同${basedir};
    ${project.version} 表示项目版本,与${version}相同;
    ${project.build.directory} 构建目录,缺省为target
    ${project.build.sourceEncoding} 表示主源码的编码格式;
    ${project.build.sourceDirectory} 表示主源码路径;
    ${project.build.finalName} 表示输出文件名称;
    ${project.build.outputDirectory} 构建过程输出目录,缺省为target/classes

    如何在Maven项目中引入本地包呢?

    比如我从其它项目打一个jar包,引入到现有项目中。

    方法一:将待引入的包放在目录下如lib目录下,修改pom文件,加入依赖并且scope要设置为system

    <dependencies>
        <dependency>
            <groupId>com.fbcds</groupId>
            <artifactId>fbcds</artifactId>
            <version>1.0</version>
            <scope>system</scope>
            <systemPath>${project.basedir}/lib/fbcds.jar</systemPath>
        </dependency>
    </dependencies>

    image
    上面设置完成后,运行mvn package命令执行成功。但打出来的包里面不包含lib目录和fbcds.jar这个引用的包,即打出来的包不是可执行的jar。所以个人开发的话可以使用这种方式,如果团队开发请使用方法二。

    方法二:将待引入的jar包安装到本地repository中

    1、先把待引入的jar包放在一个目录下,需要改一下包名,如fbcds.jar修改成fbcds-1.0.jar,如F:lib目录,在命令行CD到lib目录,执行以下命令:

    mvn install:install-file -Dfile=fbcds-1.0.jar -DgroupId=fbcds -DartifactId=fbcds -Dversion=1.0 -Dpackaging=jar
    mvn install:install-file -Dfile=ojdbc7-1.0.jar -DgroupId=ojdbc7 -DartifactId=ojdbc7 -Dversion=1.0 -Dpackaging=jar

    修改项目pom文件加入包对应的依赖

    <dependencies>
        <dependency>
            <groupId>log4j</groupId>
            <artifactId>log4j</artifactId>
            <version>1.2.17</version>
        </dependency>
        <dependency>
            <groupId>fbcds</groupId>
            <artifactId>fbcds</artifactId>
            <version>1.0</version>
        </dependency>
        <dependency>
            <groupId>ojdbc7</groupId>
            <artifactId>ojdbc7</artifactId>
            <version>1.0</version>
        </dependency>
    </dependencies>

    上面的fbcds和ojdbc7就是新加的引用包的依赖。
    完成后,在本地仓库可看到对应的文件夹内容:
    image

    MAVEN如何打可执行的JAR包

    前提条件:已成功将待引入的jar包安装到本地repository中
    方法一、使用maven-shade-plugin插件打可执行的jar包
    插件查找链接:http://maven.apache.org/plugins/

    <!-- 使用maven-jar-plugin和maven-dependency-plugin打可执行包,引用的包放包外面文件夹下 -->
    <build>
        <plugins>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-jar-plugin</artifactId>
                <configuration>
                <excludes>
                    <exclude>**/log4j.properties</exclude>
                </excludes>
                <archive>
                    <manifest>
                        <addClasspath>true</addClasspath>
                        <mainClass>com.lwf.test.TestClass</mainClass>
                        <classpathPrefix>lib/</classpathPrefix>
                    </manifest>
                </archive>
                </configuration>
            </plugin>
            <!-- Copy project dependency -->
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-dependency-plugin</artifactId>
                <version>2.5.1</version>
                <executions>
                    <execution>
                        <id>copy-dependencies</id>
                        <phase>package</phase>
                        <goals>
                            <goal>copy-dependencies</goal>
                        </goals>
                        <configuration>
                            <!-- exclude junit, we need runtime dependency only -->
                            <includeScope>runtime</includeScope> <outputDirectory>${project.build.directory}/lib/</outputDirectory>
                        </configuration>
                    </execution>
                </executions>
            </plugin>
        </plugins>
    </build>
    

    可以看到依赖的包拷贝到了lib目录下,打的包里没有依赖包的信息,只是简单的包,不过Manifest文件class-path要包含引用名的路径

    Manifest-Version: 1.0
    Built-By: lweifeng
    Build-Jdk: 1.7.0_17
    Class-Path: lib/log4j-1.2.17.jar lib/fbcds-1.0.jar lib/ojdbc7-1.0.jar
    Created-By: Apache Maven 3.3.9
    Main-Class: com.lwf.test.TestClass
    Archiver-Version: Plexus Archiver

    onejar-maven-plugin打包是将依赖包自动归入lib目录,不解压原包,相当于在原包基础上加壳,这样可以避免冲突的发生。

    现用idea maven 打jar包

     <build>
            <finalName>vv2.0Server</finalName>
            <plugins>
                <!-- 跳过单元测试 -->
                <plugin>
                    <groupId>org.apache.maven.plugins</groupId>
                    <artifactId>maven-surefire-plugin</artifactId>
                    <configuration>
                        <skip>true</skip>
                    </configuration>
                </plugin>
    
                <plugin>
                    <groupId>org.springframework.boot</groupId>
                    <artifactId>spring-boot-maven-plugin</artifactId>
                    <configuration>
                        <arguments>
                            <extdirs>${basedir}/src/lib</extdirs>
                        </arguments>
                    </configuration>
                </plugin>
            </plugins>
    
            <!-- 打jar包部署时,需要取消注释 -->
         <resources>
             <resource>
                 <directory>src/lib</directory>
                 <targetPath>BOOT-INF/lib/</targetPath>
                 <includes>
                     <include>**/*.jar</include>
                 </includes>
             </resource>
             <resource>
                 <directory>src/main/resources</directory>
                 <targetPath>BOOT-INF/classes/</targetPath>
             </resource>
         </resources>
        </build>

    参考博文

  • 相关阅读:
    Java 9 模块解耦的设计策略
    Spring Data JPA 事务锁
    如何配置Spring Boot Tomcat
    Spring Cloud Turbine
    Spring Boot 测试时的日志级别
    Spring Boot中使用RSocket
    构造函数
    递归函数的使用
    有序数列的二分搜索
    Java第一次代码作业汇总
  • 原文地址:https://www.cnblogs.com/lvgo/p/13275873.html
Copyright © 2011-2022 走看看