1.maven的属性设置
<properties> 设置maven的常用属性
<properties>
<!-- Maven构建项目使用的编码方式,防止中文乱码 -->
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<!--编译java代码使用的jdk版本,默认生成是1.7,这里改成1.8-->
<maven.compiler.source>1.8</maven.compiler.source>
<!--你的java项目运行在生么样的jdk版本,默认生成是1.7,这里改成1.8-->
<maven.compiler.target>1.8</maven.compiler.target>
</properties>
2.maven的全局变量
自定义的属性,
1.在<properties> 通过自定义标签声明变量(标签名就是变量名)
2.在pom.xml文件中的其它位置,使用 ${标签名} 使用变量的值
自定义全局变量一般是定义依赖的版本号, 当你的项目中要使用多个相同的版本号,
先使用全局变量定义, 在使用${变量名}
< dependency>
<groupId>org.springframeworkk/groupId>
<artifactId>spring-core</artifactId>
<version>5.2.5</version>
</ dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring - aop</artifactId>
<version>5.2.5</version>
</dependency>
<dependency>
< groupId>org.springframework</groupId>
< artifactId> spring- contexts /artifactId>
<version>5.2.5</version>
</ dependency>
主要是方便修改,比如下面的spring,多个模块我们都用的5.2.5,如果我们想要修改,难道3个都要去改吗,解决方法是先在properties中定义全局变量,再在version中引用全局变量
在 Maven 的 pom.xml 文件中,用于定义全局变量,POM 中通过${property_name}的形式引用变量的值。
定义全局变量:
<properties>
<spring.version>4.3.10.RELEASE</spring.version>
</properties>
引用全局变量:
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
<version>${spring.version}</version>
</dependency>
Maven 系统采用的变量:
<properties>
<maven.compiler.source>1.8</maven.compiler.source> 源码编译 jdk 版本
<maven.compiler.target>1.8</maven.compiler.target> 运行代码的 jdk 版本
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> 项目构建使用的编码,避免中文乱码
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding> 生成报告的编码
</properties>
3.资源插件
src/main/java 和 src/test/java 这两个目录中的所有*.java 文件会分别在 comile 和 test-comiple 阶段被编译,编译结果分别放到了 target/classes 和 targe/test-classes 目录中,但是这两个目录中的其他文件都会被忽略掉,如果需要把 src 目录下的文件包放到 target/classes 目录,作为输出的 jar 一部分。需要指定资源文件位置。以下内容放到标签中。
<build>
<resources>
<resource>
<directory>src/main/java</directory><!--所在的目录-->
<includes><!--包括目录下的.properties,.xml 文件都会扫描到-->
<include>**/*.properties</include>
<include>**/*.xml</include>
</includes>
<!—filtering 选项 false 不启用过滤器, *.property 已经起到过滤的作用了 -->
<filtering>false</filtering>
</resource>
</resources>
</build>
作用: mybatis课程中会用到这个作用
1 默认没有使用resources的时候, maven执行编译代码时, 会把src/main/resource目录中的文件拷贝到target/classes目录中。对于src/main/java目录下的非java文件不处理,不拷贝到target/classes目录中
2我们的程序有需要把一些文件放在 src/main/java目 录中,当 我在执行java程序时,需要用到src/main/java目录中的文件。需要告诉maven在mvn compile src/main/java目录 下的程序时,需要把文件一同拷贝到target/classes目录中。此时就需要在中 加入。