Maven基础

Maven基础

相对于对于jar包的导入 jar包不统一 jar包不兼容

项目管理工具

POM(Project Object Model)项目对象模型

仓库

私服

  • 是存在于 本地与中央服中间 私服由公司单位自主进行建立自行维护
  • 提高访问速度 或者 知识产权保护

中央服

  • maven自行建立的 服务 存放所有 所需 maven公司进行维护

坐标

坐标的组成 
- 组织ID
- 项目ID
- 版本号
- 【范围】

通过    mvnrepository.com网站取寻找想要用的文件 复制相应的maven坐标 在pom.xml中进行 配置

添加 log4j2.17.1

<!-- https://mvnrepository.com/artifact/org.apache.logging.log4j/log4j-core -->
<dependency>
    <groupId>org.apache.logging.log4j</groupId>
    <artifactId>log4j-core</artifactId>
    <version>2.17.1</version>
</dependency>

本地仓库的建立

maven 的conf目录下 setting.xml文件

<localRepository> 目标路径 </localRepository>

配置镜像仓库

conf目录下setting.xml文件中

<!-- maven镜像-->
    <mirror>
      <id>nexus-aliyun</id>
      <mirrorOf>central</mirrorOf>
      <name>Nexus aliyun</name>
      <url>https://maven.aliyun.com/repository/central </url>
      <blocked>true</blocked>
    </mirror>
  </mirrors>

maven指令

mvn compile 编译

mvn clean  清理

mvn test  测试

mvn package  打包

mvn install 安装到本地仓库


创建Maven项目

  • 创建 Java项目
idea中创建 创建项目 选择 maven 选择 从原型库创建  选择 quickstart 进行创建  再自行创建 源码文件 resource
  • 创建web项目
idea中创建项目 选择 maven 从原型库中创建 选择 webapp 进行创建
<?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">
<!--   指定pom模型版本-->
    <modelVersion>4.0.0</modelVersion>
    
<!--组织ID-->
    <groupId>org.example</groupId>
<!--项目ID-->
    <artifactId>Springdemo</artifactId>
<!--版本号-->
    <version>1.0-SNAPSHOT</version>
    <properties>
        <maven.compiler.source>16</maven.compiler.source>
        <maven.compiler.target>16</maven.compiler.target>
    </properties>
    
    <!--  设置当前工程的所有依赖    当存在多个依赖时 应 每一个依赖 建立一个<dependency></dependency>   -->
        <dependencies>
        
     <!-- 设置具体的依赖 -->
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-context</artifactId>
            <version>5.0.5.RELEASE</version>
        </dependency>
    </dependencies>
    
<!--构建-->
     <build>
 <!-- 插件-->
        <plugins>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-war-plugin</artifactId>
                <version>3.3.1</version>
            </plugin>
        </plugins>
    </build>   

依赖传递

当在一个项目中 不同的模块之间相互使用 时候 可以使用 依赖传递

并且在 引用的资源中 使用的依赖 在模块中 一样可以使用

直接配置 的依赖 为直接依赖

通过 资源配置 引入的 依赖称为 间接依赖

具体是 

将 模块2 的 groupId 、artifactId 、version 配置到 要使用该模块的 pom.xml中 

例如 : 将 01star作为资源 配置进入 当前模块中 
 <!--  设置当前工程的所有依赖    当存在多个依赖时 应 每一个依赖 建立一个<dependency></dependency>   -->
        <dependencies>
      
     <!-- 设置具体的依赖 -->
        <dependency>
     		<groupId>com.example</groupId>
   		 	<artifactId>_01Star</artifactId>
    		<version>1.0-SNAPSHOT</version>
        </dependency>
    </dependencies>

依赖冲突

依赖传递中的冲突问题

  • 路径优先:

    以当前项目为根 间接依赖一次 标注 1度2度。。。。。。

    当依赖中出现相同资源时候 层级越深 优先级越低 层级越浅 优先级越高

  • 声明优先:

    当资源在相同的层级被依赖时 配置顺序前的覆盖配置靠后的

  • 特殊优先:

    当同级别配置了相同的 资源的不同的版本 后配置的覆盖先配置的

可选依赖

可选依赖是指 对外隐藏 当前所选的资源-- 不透明

     <dependencies>
     <!-- 设置具体的依赖 -->
        <dependency>
     		<groupId>com.example</groupId>
   		 	<artifactId>_01Star</artifactId>
    		<version>1.0-SNAPSHOT</version>
        
            <optional>true</optional>  <!--这里默认为false-->
        
         
         </dependency>
    </dependencies>

排除依赖

将间接依赖指定排除

     <dependencies>
     <!-- 设置具体的依赖 -->
        <dependency>
     		<groupId>com.example</groupId>
   		 	<artifactId>_01Star</artifactId>
    		<version>1.0-SNAPSHOT</version>
       		<exclusions> <!--需要排除的所有依赖-->
       			<exclusion> <!-- 需要排除的具体依赖-->
       					<!-- 需要排除的依赖的具体信息-->
       				<groupId>com.example</groupId>
   		 			<artifactId>_01Star</artifactId>
  					<!--不需要添加版本号 因为如果是排除将排除所有的版本-->
       			
      			</exclusion> 		
       		</exclusions>
        
         
         </dependency>
    </dependencies>



依赖范围

依赖的jar 默认情况下是可以在任何情况下都以使用 可以通过 scpoe 标签设定 其作用范围

作用范围:

  • 主程序范围有效 (main文件范围内)
  • 测试程序范围有效(test文件范围内)
  • 是否参与打包(package指令范围内)

参数:

  • compile 默认 所有范围均有效
  • test 测试范围有效
  • provided 除了打包都有效 (servlet-api)
  • runtime 只有在打包时有效
例子:
			<groupId>com.example</groupId>
   		 	<artifactId>_01Star</artifactId>
    		<version>1.0-SNAPSHOT</version>
			<scope>runtime</scope>

依赖范围也具有传递性 (了解)

生命周期

compile - testcompile -test - package - install

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值