01. Maven 工具的安装以及项目的创建
1、Maven简介
- Maven是 Apache软件基金会的一个开源项目
- 它用来帮助开发者管理项目中的jar,以及jar之间的依赖关系
- 完成项目的编译、测试、打包和发布等工作
Pom(Project Object Model 项目对象模型)
- Maven 管理的项目的根目录下都有一个 pom.xml 文件
- pom.xml 文件指示 Maven 如何工作
- pom.xml 文件中配置项目基本信息以及项目构建信息等。比如:项目坐标、项目依赖的 jar、插件、编译选项等。
- 一旦在 pom.xml 文件中配置了所依赖的 jar,Maven 会自动从构件仓库中下载相应的构件。
2、项目坐标
在 Maven 中,将每个项目最终生成的文件称为 artifact(构件),它可以是 jar 文件,也可以是 war 文件。
groupId、artifactId、packaging、version 的组合被称为项目的坐标,它们形成了项目的唯一标识,Maven
通过坐标来精确定位构件。其中 groupId、artifactId、version 是必须的,且这三项的值必须唯一,packaging是可选的(默认为 jar)。
组成元素:
groupId 组Id
artifactId 组件Id
packaging 包类型
version 版本
在项目中使用jar,需要在pom.xml 文件配置jar的坐标,maven 首先去本地仓库找,如果找不到就会去中央仓库找。
3、仓库
中央仓库全球共享,先将jar从中央仓库下载到本地仓库,然后在项目中引用本地仓库的jar.
本地仓库就是本地的仓库,里面存放着jar包。
4、Maven 开发环境搭建
4.1 下载maven服务器
maven官网:
http:// maven.apache. org
点击download进行下载如下图
4.2 配置maven
(1)将下载二进制的apache-maven-3.5.2-bin.zip进行解压,然后在系统环境中配置环境变量,在path中配置到bin目录,配置成功后输入命令mvn -version
(2)配置settings.xml文件
在maven的服务器解压的文件中找到conf文件夹下的settings.xml文件进行修改:
1)修改本地仓库位置
现在自己磁盘中创建一个文件夹mavenRepository,我是在D:\mavenRepository
然后在settings.xml文件中找到setting标签,把里面的localRepository中的路径改为D:\mavenRepository,并取消注释。
<!--配置本地仓库位置,从中央仓库下载的jar包都 会存储到这个目录-->
<localRepository>D:\mavenRepository</localRepository>
2)修改为阿里云的maven镜像仓库
找到mirror标签,进行修改
<!--配置中央镜像仓库 阿里云服务器地址 下载速度快 -->
<mirror>
<id>alimaven</id>
<name>aliyun maven</name>
<url>http://maven.aliyun.com/nexus/content/groups/public/</url>
<mirrorOf>central</mirrorOf>
</mirror>
3)修改jdk版本信息
找到profiles标签,添加下面代码,如下图:
<!--配置jdk版本 -->
<profile>
<id>jdk-1.8</id>
<activation>
<activeByDefault>true</activeByDefault>
<jdk>1.8</jdk>
</activation>
<properties>
<maven.compiler.source>1.8</maven.compiler.source>
<maven.compiler.target>1.8</maven.compiler.target>
<maven.compiler.compilerVersion>1.8</maven.compiler.compilerVersion>
</properties>
</profile>
到此为止,settings.xml文件就配置完成了!!!
(3)在eclipse中配置maven插件
- 在eclipse中打开Window-> Preferences->Maven
- 在Installations 中添加apache-maven-3.5.4安装根目录
-
在User Settings中,配置settings.xml文件路径
到此为止,Maven就配置完成了!!!
5、创建Maven工程
(1)
(2)
(3)
(4)第一次创建项目,需要从maven仓库下载jar包
(5)进来之后如果会报错,需要点击这个
6、如何在Maven中导入jar包
6.1 导入中央仓库包
(1)在Maven仓库官网上,找到使用的jar的仓库文件路径
Maven仓库地址:https://mvnrepository.com/
(2)直接搜索 需要的jar包名,比如:jstl
(3)找到想要的版本
(4)复制仓库地址
(5)粘贴到项目中pom.xml文件的dependencies标签中,如果没有创建dependencies标签。粘贴后保存,eclipse会自动从仓库中下载jar包到本地仓库。
<dependencies>
<!-- https://mvnrepository.com/artifact/javax.servlet/jstl -->
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>jstl</artifactId>
<version>1.2</version>
</dependency>
</dependencies>
(6)导入servlet-api包
<!-- https://mvnrepository.com/artifact/javax.servlet/javax.servlet-api -->
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>javax.servlet-api</artifactId>
<version>4.0.1</version>
<!-- scope: 默认值是compile ,当项目最终打包时,会将jar包拷贝到项目的lib目录中;
provided,服务器中或者JDK中已经包含了这些jar包,只在本地编译时需要,所以打包的时候不会被拷贝
-->
<scope>provided</scope>
</dependency>
各个子元素功能解释:
<groupId>,<artifactId>和<version>:依赖项的基本坐标
<type>:依赖项的 packaging 类型,默认是 jar;
<scope>:依赖项的作用范围,默认是 compile。各个取值及含义如下:
compile:编译时和运行时依赖。如果你的项目最终打包为 war 包,则该依赖包会被拷贝到 war 包中的 lib 目录中。
provided:编译项目主代码和测试代码时使用此依赖项,运行时由 jre 或 web 容器提供。如果你的项目最终打包为 war 包,则该 jar 包不会被打包。
6.2 导入本地包
我们除了可以导入人家的中央仓库包,也可以把我们自己写的java程序打包进行导入,作为这个项目的一个工具包。
导入方式和上述方式一致:
<dependency>
<groupId>com.company</groupId>
<artifactId>MyUtil-0.0.1-SNAPSHOT</artifactId>
<version>1.0.0</version>
</dependency>
7、使用maven打包
(1)右击 pom.xml文件或者 右击项目,选择 Run as
(2)先选择Maven clear清除上次打包的版本
(3)再选择Maven install进行打包,打包好的jar文件会存放到本地仓库中。
(4)更新仓库:项目右键->Maven->Update Project…
8、使用log4j
log4j是 apche 提供的一款日志组件
8.1 如何使用
(1)导入jar包
<!-- log4j -->
<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>1.2.17</version>
</dependency>
(2)导入 log4j 的配置文件 log4j.properties,源码如下,没有的可以手动创建
log4j.rootLogger = debug,stdout,D
#System out Console
log4j.appender.stdout = org.apache.log4j.ConsoleAppender
log4j.appender.stdout.Target = System.out
log4j.appender.stdout.layout = org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern = [%p] %d{yyyy-MM-dd HH:mm:ss,SSS} %m%n
#System out File
log4j.appender.D = org.apache.log4j.FileAppender
log4j.appender.D = org.apache.log4j.DailyRollingFileAppender
log4j.appender.D.File = E://logs/log.log
log4j.appender.D.Append = true
log4j.appender.D.layout = org.apache.log4j.PatternLayout
log4j.appender.D.layout.ConversionPattern = %d{yyyy-MM-dd HH:mm:ss} [ %t:%r ] - [ %p ] -[%l] %m%n
(3)在之前任意使用System.out.println();的地方现在都可以使用 log4j 代替。
import org.apache.log4j.Logger;
public class Demo {
public static void main(String[] args) {
Logger logger = Logger.getLogger(Demo.class);
logger.debug("日志已经调试好");
}
}
8.2 日志级别
每个Logger都被了一个日志级别(log level),用来控制日志信息的输出。日志级别从高到低分为:
A:off 最高等级,用于关闭所有日志记录。
B:fatal 指出每个严重的错误事件将会导致应用程序的退出。
C:error 指出虽然发生错误事件,但仍然不影响系统的继续运行。
D:warm 表明会出现潜在的错误情形。
E:info 一般和在粗粒度级别上,强调应用程序的运行全程。
F:debug 一般用于细粒度级别上,对调试应用程序非常有帮助。
G:all 最低等级,用于打开所有日志记录。
上面这些级别是定义在org.apache.log4j.Level类中。Log4j只建议使用4个级别,优先级从高到低分别是error,warn,info和debug。通过使用日志级别,可以控制应用程序中相应级别日志信息的输出。例如,如果使用b了info级别,则应用程序中所有低于info级别的日志信息(如debug)将不会被打印出来。
Log4J采用类似C语言中的printf函数的打印格式格式化日志信息,打印参数如下:
%m 输出代码中指定的消息
%p 输出优先级,即DEBUG,INFO,WARN,ERROR,FATAL
%r 输出自应用启动到输出该log信息耗费的毫秒数
%c 输出所属的类目,通常就是所在类的全名
%t 输出产生该日志事件的线程名
%n 输出一个回车换行符,Windows平台为“rn”,Unix平台为“n”
%d 输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式,比如:%d{yyy MMM dd HH:mm:ss,SSS},输出类似:2002年10月18日 22:10:28,921
%l 输出日志事件的发生位置,包括类目名、发生的线程,以及在代码中的行数。举例:Testlog4.main(TestLog4.java:10)