# 观念

明确一个意识:从来只有 web 工程依赖 java 工程,没有反过来 java 工程依赖 web 工程,本质上来说,web 工程依赖的 java 工程其实就是 web 工程里导入的 jar 包,最终 java 工程会变成 jar 包,放在 web 工程的 WEB-INF/lib 目录下

# 操作

在 pro02-maven-web 工程的 pom.xml 中,找到 dependencies 标签,在 dependencies 标签中做如下配置:

<!-- 配置对 java 工程 pro01-maven-java 的依赖 -->
<!-- 具体的配置方式:在 dependency 标签内使用坐标实现依赖 -->
<dependency>
    <groupId>com.dkx.maven</groupId>
    <artifactId>pro01-maven-java</artifactId>
    <version>1.0-SNAPSHOT</version>
</dependency>

# 补充创建目录

pro02-maven-web\src\test\java\com\dkx\maven

# 确认 web 工程依赖了 junit

# 创建测试类

把 java 工程的 CalculatorTest.java 复制到 pro02-maven-web\src\test\java\com\dkx\maven 目录下

# 执行 maven 命令

测试命令

mvn test

说明:测试操作中会提前自动执行编译操作,测试成功寿命编译也是成功的

打包命令

mvn package

image-20240208131736660

通过查看 war 包内的结构,我们看到被 web 工程依赖的 java 工程确实是会变成 web 工程的 WEB-INF/lib 目录下的 jar 包

image-20240208131802221

查看当前 web 工程所依赖的 jar 包列表

mvn dependency:list

image_2023-01-12-13-54-50

这样我们的格式虽然和我们 XML 配置文件中坐标的格式不同,但是本质上还是坐标信息,大家需要能够认识这样的格式,将来从 Maven 命令的日志或错误信息中看到这样格式的信息,就能够识别出来这是坐标,进而根据坐标到 Maven 仓库找到对应的 jar 包,用这样的方式解决我们遇到的报错的情况

# 以树形结构查看当前 web 工程的依赖信息

mvn dependency:tree

image-20240208131819600

我们在 pom.xml 中并没有依赖 hamcrest-core, 但是它却被加入了我们依赖的列表,原因是:junit 依赖了 hamcrest-core, 然后基于依赖的传递性,hamcrest-core 被传递到我们的工程了