父工程Project空间新建

创建maven工程

1610803427736.png

1610803427762.png

下一步:

Maven home directory: D:/apache-maven-3.5.4-bin/apache-maven-3.5.4

Local repository: D:\Docments\m2\repository

字符编码

  • File->settings
  • File Encodings
    • Global Encoding: UTF-8
    • Project Encoding: UTF-8
    • Default encoding for properties files: UTF-8
    • 勾选Transparent native-to-ascii conversion

注解生效激活

  • File->settings
  • Annotation Processors
    • 勾选Enable annotation processing

java编译版本选8

  • File->settings
  • Java compiler
    • 将Target bytecode version改成8

File Type过滤

不显示工程下的 .xxx文件,一般我们不需要动

  • File->settings
  • File Types
    • lgnore files and folders: 加入如下内容 *.idea;*.iml;

父工程pom文件

把刚才新创建的工程除了pom.xml文件留着,其余全部删除

子模块继承之后,提供作用:锁定版本+ 子modlue不用写 groupId和version

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  3. xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
  4. <modelVersion>4.0.0</modelVersion>
  5. <groupId>com.sgy.cloud2020</groupId>
  6. <artifactId>cloud2020</artifactId>
  7. <version>1.0-SNAPSHOT</version>
  8. <packaging>pom</packaging>
  9. <!--统一管理jar包版本-->
  10. <properties>
  11. <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
  12. <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
  13. <maven.compiler.source>1.8</maven.compiler.source>
  14. <maven.compiler.target>1.8</maven.compiler.target>
  15. <java.version>1.8</java.version>
  16. <fastjson.version>1.2.46</fastjson.version>
  17. <lombok.version>1.18.12</lombok.version>
  18. <druid-version>1.1.21</druid-version>
  19. <log4j-over-slf4j.version>1.7.26</log4j-over-slf4j.version>
  20. <httpclient.version>4.5.5</httpclient.version>
  21. <commons-lang3.version>3.7</commons-lang3.version>
  22. <beanUtils.version>1.9.3</beanUtils.version>
  23. <mybatis.spring.boot.starter.version>2.0.1</mybatis.spring.boot.starter.version>
  24. <mapper.spring.boot.starter.version>2.1.5</mapper.spring.boot.starter.version>
  25. <junit.version>4.13</junit.version>
  26. </properties>
  27. <dependencyManagement>
  28. <dependencies>
  29. <!-- springboot 2.2.2 -->
  30. <dependency>
  31. <groupId>org.springframework.boot</groupId>
  32. <artifactId>spring-boot-dependencies</artifactId>
  33. <version>2.2.2.RELEASE</version>
  34. <type>pom</type>
  35. <scope>import</scope>
  36. </dependency>
  37. <!--spring cloud Hoxton.SR1-->
  38. <dependency>
  39. <groupId>org.springframework.cloud</groupId>
  40. <artifactId>spring-cloud-dependencies</artifactId>
  41. <version>Hoxton.SR1</version>
  42. <type>pom</type>
  43. <scope>runtime</scope>
  44. </dependency>
  45. <dependency>
  46. <groupId>com.alibaba.cloud</groupId>
  47. <artifactId>spring-cloud-alibaba-dependencies</artifactId>
  48. <version>2.1.0.RELEASE</version>
  49. <type>pom</type>
  50. <scope>import</scope>
  51. </dependency>
  52. <!-- https://mvnrepository.com/artifact/junit/junit -->
  53. <dependency>
  54. <groupId>junit</groupId>
  55. <artifactId>junit</artifactId>
  56. <version>${junit.version}</version>
  57. <scope>test</scope>
  58. </dependency>
  59. <dependency>
  60. <groupId>org.projectlombok</groupId>
  61. <artifactId>lombok</artifactId>
  62. <version>${lombok.version}</version>
  63. <scope>provided</scope>
  64. </dependency>
  65. <dependency>
  66. <groupId>com.alibaba</groupId>
  67. <artifactId>fastjson</artifactId>
  68. <version>${fastjson.version}</version>
  69. </dependency>
  70. <!-- 阿里巴巴数据库连接池: druid -->
  71. <dependency>
  72. <groupId>com.alibaba</groupId>
  73. <artifactId>druid</artifactId>
  74. <version>${druid-version}</version>
  75. </dependency>
  76. <dependency>
  77. <groupId>org.slf4j</groupId>
  78. <artifactId>log4j-over-slf4j</artifactId>
  79. <version>${log4j-over-slf4j.version}</version>
  80. </dependency>
  81. <dependency>
  82. <groupId>org.mybatis.spring.boot</groupId>
  83. <artifactId>mybatis-spring-boot-starter</artifactId>
  84. <version>${mybatis.spring.boot.starter.version}</version>
  85. </dependency>
  86. <!-- https://mvnrepository.com/artifact/org.jsoup/jsoup -->
  87. <dependency>
  88. <groupId>org.jsoup</groupId>
  89. <artifactId>jsoup</artifactId>
  90. <version>${jsoup.version}</version>
  91. </dependency>
  92. <!-- https://mvnrepository.com/artifact/org.apache.httpcomponents/httpclient -->
  93. <!--
  94. 通过java可以发送http协议,相当于java版本的浏览器,可以直接访问www.baidu.com,然后通过java
  95. 接收数据
  96. -->
  97. <dependency>
  98. <groupId>org.apache.httpcomponents</groupId>
  99. <artifactId>httpclient</artifactId>
  100. <version>${httpclient.version}</version>
  101. </dependency>
  102. <!--
  103. commons-lang3是用于针对java.lang类中数据基本类型的处理工具包
  104. 比如判断字符串是否为空if(StringUtils.isblank(s))
  105. -->
  106. <dependency>
  107. <groupId>org.apache.commons</groupId>
  108. <artifactId>commons-lang3</artifactId>
  109. <version>${commons-lang3.version}</version>
  110. </dependency>
  111. <!--
  112. 通用mapper依赖包
  113. -->
  114. <dependency>
  115. <groupId>tk.mybatis</groupId>
  116. <artifactId>mapper-spring-boot-starter</artifactId>
  117. <version>${mapper.spring.boot.starter.version}</version>
  118. </dependency>
  119. <dependency>
  120. <groupId>commons-beanutils</groupId>
  121. <artifactId>commons-beanutils</artifactId>
  122. <version>${beanUtils.version}</version>
  123. </dependency>
  124. <dependency>
  125. <groupId>org.redisson</groupId>
  126. <artifactId>redisson</artifactId>
  127. <version>${redisson.version}</version>
  128. </dependency>
  129. </dependencies>
  130. </dependencyManagement>
  131. </project>

DependencyManagement和Dependencies关系

dependencyManagement应用场景

  为了项目的正确运行,必须让所有的子模块使用依赖项的统一版本,必须确保应用的各个项目的依赖项和版本一致,才能保证测试的和发布的是相同的结果。在我们项目顶层的pom文件中,我们会看到dependencyManagement元素。通过它元素来管理jar包的版本,让子项目中引用一个依赖而不用显示的列出版本号。Maven会沿着父子层次向上走,直到找到一个拥有dependencyManagement元素的项目,然后它就会使用在这个dependencyManagement元素中指定的版本号。

父pom中dependencyManagement如下:

   <modules>
        <module>module1</module>
    </modules>
    <properties>
            <spring-version>3.1.1.RELEASE</spring-version>
    </properties>

    <dependencyManagement>
          <dependency>
                <groupId>org.springframework</groupId>
                <artifactId>spring-web</artifactId>
                <version>${spring-version}</version>
          </dependency>
    </dependencyManagement>

子模块module1中dependency声明如下所示:

   <dependencies>
            <dependency>
                  <groupId>org.springframework</groupId>
                  <artifactId>spring-web</artifactId>
            </dependency>
    </dependencies>

  这样做的好处:统一管理项目的版本号,确保应用的各个项目的依赖和版本一致,才能保证测试的和发布的是相同的成果,因此,在顶层pom中定义共同的依赖关系。同时可以避免在每个使用的子项目中都声明一个版本号,这样想升级或者切换到另一个版本时,只需要在父类容器里更新,不需要任何一个子项目的修改;如果某个子项目需要另外一个版本号时,只需要在dependencies中声明一个版本号即可。子类就会使用子类声明的版本号,不继承于父类版本号。

dependencyManagement与dependencies区别

  dependencyManagement里只是声明依赖,并不实现引入,因此子项目需要显式的声明需要用的依赖。如果不在子项目中声明依赖,是不会从父项目中继承下来的;只有在子项目中写了该依赖项,并且没有指定具体版本,才会从父项目中继承该项,并且version和scope都读取自父pom;另外如果子项目中指定了版本号,那么会使用子项目中指定的jar版本。

dependencies即使在子模块中不写该依赖项,那么子模块仍然会从父项目中继承该依赖项(全部继承)。

在实际的项目开发中,推荐在父pom中使用dependencyManagement对项目中使用到的依赖包进行统一的管理。

父工程创建完成执行mvn: install将父工程发布到仓库方便子工程继承