精通系列)安装+基本使用+项目创建+项目部署+文件操作+依赖管理+插件使用
Posted 蓝盒子itbluebox
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了精通系列)安装+基本使用+项目创建+项目部署+文件操作+依赖管理+插件使用相关的知识,希望对你有一定的参考价值。
Gradle文章目录 | |
---|---|
Java之Gradle【IDEA版】入门到精通(上)(一篇文章精通系列)【安装+基本使用+项目创建+项目部署+文件操作+依赖管理+插件使用】 | |
Java之Gradle【IDEA版】入门到精通(下)(一篇文章精通系列)【创建 Springboot 项目+基于 ssm 多模块项目案例+微服务实战】 |
Java之Gradle【IDEA版】入门到精通(一篇文章精通系列)
- 1、Gradle 入门
- 2、Idea当中使用Gradle(普通java 工程)
- 3、在 idea 中创建 web 工程(SSM)
- 4、项目部署(Tomcat)
- 5、Gretty 部署项目
- 6、Gretty 对测试的支持
- 7、Gradle 进阶说明
- 7.1、项目的生命周期
- 7.2、settings 文件
- 7.3、Task
- 7.3.1、任务入门
- 7.3.2、任务的行为
- 7.3.3、任务的依赖方式
- 7.3.4、任务执行(常用命令)
- (1)`gradle run` :运行一个服务,需要application 插件支持,并且指定了主启动类才能运行
- (2)`gradle task` 列出所选项目【当前 project,不包含父、子】的已分配给任务组的那些任务。
- (3)`gradle tasks --all` :列出所选项目的所有任务。
- (4)`gradle tasks --group="build setup"`:列出所选项目中指定分组中的任务。
- (5)`gradle help --task someTask` :显示某个任务的详细信息
- (6)`gradle dependencies` :查看整个项目的依赖信息,以依赖树的方式显示
- (7)`gradle properties` 列出所选项目的属性列表
- (8)`gradle --help` 列出所有命令
- (9)`gradle init --type pom` :将maven 项目转换为gradle 项目(根目录执行)
- (10)`gradle [taskName]` :执行自定义任务
- 7.3.5、任务定义方式
- 7.3.6、任务类型
- 7.3.7、任务的执行顺序
- 7.3.8、动态分配任务
- 7.3.9、任务的关闭与开启
- 7.3.10、任务的超时
- 7.3.11、任务的查找
- 7.3.12、任务的规则
- 7.3.13、任务的 onlyIf 断言
- 7.3.14、默认任务
- 8、Gradle 中的文件操作
- 9、Dependencies
- 10、Gradle 插件
- 11、publishing 项目发布
- 12、生命周期中Hook
1、Gradle 入门
1.1、Gradle 简介
Gradle 是一款Google 推出的基于 JVM、通用灵活的项目构建工具,支持 Maven,JCenter 多种第三方仓库;支持传递性依赖管理、废弃了繁杂的xml 文件,转而使用简洁的、支持多种语言(例如:java、groovy 等)的 build 脚本文件。
官网地址: https://gradle.org/
学习Gradle 的原因:
- 目前已经有相当一部分公司在逐渐使用Gradle作为项目构建工具了。
- 作为Java开发程序员,如果想下载Spring、SpringBoot等Spring家族的源码,基本上基于Gradle构建的。
总之,虽然目前市面上常见的项目构建工具有Ant、Maven、Gradle,主流还是Maven,但是未来趋势Gradle。
1.2、Gradle 安装
1.2.1 下载解压
Gradle官方下载安装教程页面:https://gradle.org/install/
点击releases page.
点击:complete (checksums)
解压
1.2.2 配置环境变量
GRADLE_HOME
和
对应刚刚安装的位置路径
GRADLE_USER_HOME
和
对应Maven仓库的位置
1.2.3 在cmd当中输入命令
gradle -v 或者 gradle --version
通过gradle -v或者 gradle --version检测是否安装成功
Gradle 7.4.2安装成功的提示文本
1.3、Gradle 项目目录结构
Gradle 项目默认目录结构和Maven 项目的目录结构一致
都是基于约定大于配置【Convention Over Configuration】。其完整项目目录结构如下所示:
Tips:
- 只有war工程才有webapp目录,对于普通的jar工程并没有webapp目录
- gradlew与gradlew.bat执行的指定wrapper版本中的gradle指令,不是本地安装的gradle指令哦。
1.4、Gradle 创建第一个项目
1.4.1 通过脚手架创建项目
通过https://start.spring.io/,脚手架创建项目
1.4.2 通过Gradle命令创建项目
创建gradle02目录
进入gradle02目录,在地址栏当中输入cmd
输入
gradle init
输入no
下面直接回车项目名称使用默认文件夹名称
创建成功
1.5 Gradle 中的常用指令
Gradle 常用命令说明:
常用gradle指令 | 作用 |
---|---|
gradle clean | 清空build目录 |
gradle classes | 编译业务代码和配置文件 |
gradle test | 编译测试代码,生成测试报告 |
gradle build | 构建项目 |
gradle build -x test | 跳过测试构建 |
需要注意的是:gradle 的指令要在含有build.gradle 的目录执行。
1.6 修改maven 下载源
Gradle 自带的Maven 源地址是国外的,该Maven 源在国内的访问速度是很慢的,除非使用了特别的手段。
一般情况下,我们建议使用国内的第三方开放的Maven 源或企业内部自建Maven 源。
认识init.d 文件夹
我们可以在gradle 的init.d 目录下创建以.gradle 结尾的文件,.gradle 文件可以实现在build 开始之前执行,所以你可以在这个文件配置一些你想预先加载的操作。
在init.d 文件夹创建init.gradle
文件
allprojects
repositories
mavenLocal()
maven name "Alibaba" ; url "https://maven.aliyun.com/repository/public"
maven name "Bstek" ; url "https://nexus.bsdn.org/content/groups/public/"
mavenCentral()
buildscript
repositories
maven name "Alibaba" ; url 'https://maven.aliyun.com/repository/public'
maven name "Bstek" ; url 'https://nexus.bsdn.org/content/groups/public/'
maven name "M2" ; url 'https://plugins.gradle.org/m2/'
设置M2_HOME的配置
拓展说明
拓展 1:启用init.gradle
文件的方法有:
1.在命令行指定文件,例如:gradle --init-script yourdir/init.gradle -q taskName
。你可以多次输入此命令来指定多个init文件2.把init.gradle文件放到 USER_HOME/.gradle/
目录下
- 把以.gradle结尾的文件放到
USER_HOME/.gradle/init.d/
目录下 - 把以.gradle结尾的文件放到
GRADLE_HOME/init.d/
目录下
如果存在上面的4种方式的2种以上,gradle会按上面的1-4序号依次执行这些文件,如果给定目录下存在多个init脚本,会按拼音a-z顺序执行这些脚本,每个init脚本都存在一个对应的gradle实例,你在这个文件中调用的所有方法和属性,都会委托给这个gradle实例,每个init脚本都实现了Script接口。
拓展 2:仓库地址说明
mavenLocal():
指定使用maven本地仓库,而本地仓库在配置maven时settings文件指定的仓库位置。
如E:/repository,gradle
查找jar包顺序如下:USER_HOME/.m2/settings.xml >> M2_HOME/conf/settings.xml >> USER_HOME/.m2/repository
maven url 地址
,指定maven仓库,一般用私有仓库地址或其它的第三方库【比如阿里镜像仓库地址】。
mavenCentral()
:这是Maven的中央仓库,无需配置,直接声明就可以使用。
jcenter()
:JCenter中央仓库,实际也是是用的maven搭建的,但相比Maven仓库更友好,通过CDN分发,并且支持https访问,在新版本中已经废弃了,替换为了mavenCentral()
。
总之, gradle可以通过指定仓库地址为本地maven仓库地址和远程仓库地址相结合的方式,避免每次都会去远程仓库下载依赖库。
这种方式也有一定的问题,如果本地maven仓库有这个依赖,就会从直接加载本地依赖,如果本地仓库没有该依赖,那么还是会从远程下载。
但是下载的jar不是存储在本地maven仓库中,
而是放在自己的缓存目录中,默认在USER_HOME/.gradle/caches
目录,
当然如果我们配置过GRADLE_USER_HOME
环境变量,
则会放在GRADLE_USER_HOME/caches
目录,那么可不可以将gradle caches
指向maven repository
。
我们说这是不行的,caches下载文件不是按照maven仓库中存放的方式。
拓展 3:阿里云仓库地址请参考:https://developer.aliyun.com/mvn/guide
1.7 Wrapper 包装器
Gradle Wrapper 实际上就是对 Gradle 的一层包装,用于解决实际开发中可能会遇到的不同的项目需要不同版本的 Gradle
问题。例如:把自己的代码共享给其他人使用,可能出现如下情况:
- 对方电脑没有安装 gradle
- 对方电脑安装过 gradle,但是版本太旧了
这时候,我们就可以考虑使用 Gradle Wrapper 了。这也是官方建议使用 Gradle Wrapper 的原因。实际上有了 Gradle Wrapper 之后,我们本地是可以不配置 Gradle 的,下载Gradle 项目后,使用 gradle 项目自带的wrapper 操作也是可以的。
那如何使用Gradle Wrapper 呢?
项目中的gradlew、gradlew.cmd脚本用的就是wrapper中规定的gradle版本。参见源码
而我们上面提到的gradle指令用的是本地gradle,所以gradle指令和gradlew指令所使用的gradle版本有可能是不一样的。
gradlew、gradlew.cmd的使用方式与gradle使用方式完全一致,只不过把gradle指令换成了gradlew指令。
当然,我们也可在终端执行 gradlew 指令时,指定指定一些参数,来控制 Wrapper 的生成,比如依赖的版本等,如下:
参数名 | 说明 |
---|---|
–gradle-version | 用于指定使用的Gradle版本 |
–gradle-distribution-url | 用于指定下载Gradle发行版的url地址 |
具体操作如下所示 :
gradle wrapper --gradle-version=7.4.2:
升级wrapper版本号
只是修改gradle.properties中wrapper版本,
未实际下载
gradle wrapper --gradle-version 7.4.2 --distribution-type all :
关联源码用
GradleWrapper
的执行流程:
- 当我们第一次执行
./gradlew build
命令的时候,gradlew
会读取gradle-wrapper.properties
文件的配置信息
- 准确的将指定版本的 gradle 下载并解压到指定的位置(
GRADLE_USER_HOME
目录下的wrapper/dists
目录中) - 并构建本地缓存(
GRADLE_USER_HOME
目录下的caches
目录中),下载再使用相同版本的gradle
就不用下载了 - 之后执行的
./gradlew
所有命令都是使用指定的gradle
版本。如下图所示:
gradle-wrapper.properties
文件解读:
字段名 | 说明 |
---|---|
distributionBase | 下载的Gradle压缩包解压后存储的主目录 |
distributionPath | 相对于distributionBase的解压后的Gradle压缩包的路径 |
zipStoreBase | 同distributionBase,只不过是存放zip压缩包的 |
zipStorePath | 同distributionPath,只不过是存放zip压缩包的 |
distributionUrl | Gradle发行版压缩包的下载地址 |
注意:前面提到的 GRALE_USER_HOME
环境变量用于这里的Gradle Wrapper
下载的特定版本的gradle
存储目录。
如果我们没有配置过GRALE_USER_HOME
环境变量,默认在当前用户家目录下的.gradle
文件夹中。
那什么时候选择使用 gradle wrapper
、什么时候选择使用本地gradle
?
下载别人的项目或者使用操作以前自己写的不同版本的gradle项目时:用Gradle wrapper
,也即:gradlew
什么时候使用本地gradle?
新建一个项目时: 使用gradle指令即可。
2、Idea当中使用Gradle(普通java 工程)
2.1、在 idea 中创建普通java 工程
具体整合:
第一步:创建由Gradle 管理的项目
特别提示 1:使得在Terminal
中执行以gradlew
开头命令和操作图形化的IDEA 使用Gradle 版本不一定是同一个版本哦。
1.Terminal
中以gradlew开头指令用的是Wrapper
规定的gradle
版本,wrapper
中规定版本默认和idea插件中规定的版本一致。
2.而图形化的IDEA使用Gradle是本地安装的哦。
特别提示
2:目前只能是在创建项目时重新设置本地gradle
,创建新项目需要重新去改。
特别提示3:当 我 们 在 gradle.build 文 件 添 加 依 赖 之 后 , 这 些 依 赖 会 在 下 载 到GRADLE_USER_HOME/caches/modules-2/files-2.1
目录下面,所以这里的 GRADLE_USER_HOME
相当于 Gradle
的本地仓库,当然也可以如下方式找到jar
包位置。
3、在 idea 中创建 web 工程(SSM)
3.1、在idea 创建项目
,无法自己选择创建项目是普通 java 工程还是 web 工程了【IDEA 旧版本是可以的】
,所以我们如果想创建 web 工程,只需要自己在 src/main/目录下添加webapp/WEB-INF/web.xml
及页面即可。
plugins
id 'war'
group 'com.itbluebox.gradle'
version '1.0-SNAPSHOT'
repositories
mavenCentral()
dependencies
implementation 'org.springframework:spring-beans:4.1.7.RELEASE'
implementation 'org.springframework:spring-web:4.1.7.RELEASE'
implementation 'org.springframework:spring-webmvc:4.1.7.RELEASE'
implementation 'org.springframework:spring-tx:4.1.7.RELEASE'
implementation 'org.springframework:spring-test:4.0.5.RELEASE'
implementation 'org.springframework:spring-jdbc:4.1.7.RELEASE'
implementation 'org.mybatis:mybatis-spring:1.2.3'
implementation 'org.mybatis:mybatis:3.3.0'
implementation 'mysql:mysql-connector-java:8.0.27'
implementation 'com.alibaba:druid:1.0.15'
implementation "com.fasterxml.jackson.core:jackson-databind:2.2.3"
implementation "com.fasterxml.jackson.core:jackson-annotations:2.2.3"
implementation "com.fasterxml.jackson.core:jackson-core:2.2.3"
implementation 'org.aspectj:aspectjweaver:1.8.6'
implementation 'log4j:log4j:1.2.17'
implementation 'org.slf4j:slf4j-api:1.7.25'
implementation 'jstl:jstl:1.2'
compileOnly 'javax.servlet:servlet-api:2.5'
testImplementation 'org.junit.jupiter:junit-jupiter-api:5.8.1'
testRuntimeOnly 'org.junit.jupiter:junit-jupiter-engine:5.8.1'
3.2、创建对应的目录(配置文件)
<?xml version="1.0" encoding="UTF-8"?>
<web-app version="2.4"
xmlns="http://java.sun.com/xml/ns/j2ee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee
http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd">
<context-param>
<!-- 指定spring 配置文件的路径和名称 -->
<param-name>contextConfigLocation</param-name>
<param-value>classpath:applicationContext.xml</param-value>
</context-param>
<!-- 指定spring的监听器 -->
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
<!-- 2.配置springmvc的前端控制器 -->
<servlet>
<servlet-name>DispatcherServlet</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:springmvc.xml</param-value>
</init-param>
</servlet>
<servlet-mapping>
<servlet-name>DispatcherServlet</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
<!-- 2.处理POST请求乱码的过滤器 -->
<filter>
<filter-name>CharacterEncodingFilter</filter-name>
<filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
<init-param>
<param-name>encoding</param-name>
<param-value>UTF-8</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>CharacterEncodingFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
<!-- 3.配置将POST请求转换为PUT或者DELETE请求的过滤器 -->
<filter>
<filter-name>HiddenHttpMethodFilter</filter-name>
<filter-class>org.springframework.web.filter.HiddenHttpMethodFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>HiddenHttpMethodFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
</web-app>
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:context="http://www.springframework.org/schema/context" xmlns:tx="http://www.springframework.org/schema/tx"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/context https://www.springframework.org/schema/context/spring-context.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx.xsd">
<!-- 0.配置扫描包 -->
<context:component-scan base-package="com.itbluebox">
<context:exclude-filter type="annotation" expression="org.springframework.stereotype.Controller"/>
<context:exclude-filter type="annotation" expression="org.springframework.web.bind.annotation.ControllerAdvice"/>
</context:component-scan>
<!-- 1.加载properties文件 -->
<context:property-placeholder location="classpath:jdbc.properties"></context:property-placeholder>
<!-- 2.配置数据源 -->
<bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource">
<property name="username" value="$jdbc.userName"></property>
<property name="password" value="$jdbc.password"></property>
<property name="url" value="$jdbc.jdbcUrl"></property>
<property name="driverClassName" value="$jdbc.driverClass"></property>
</bean>
<!-- 4.配置数据源事务管理器 -->
<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="dataSource"></property>
</bean>
<tx:annotation-driven transaction-manager="transactionManager"></tx:annotation-driven>
<!-- 1.配置spring整合mybatis -->
<bean class="org.mybatis.spring.SqlSessionFactoryBean">
<property name="dataSource" ref="dataSource"></property>
<property name="configLocation" value="classpath:mybatis-config.xml"></property>
</bean>
<!-- 2.配置扫描mapper接口的bean对象 -->
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<property name="basePackage" value="com.itbluebox.dao"/>
</bean>
</beans>
jdbc.jdbcUrl=jdbc:mysql://localhost:3306/test?rewriteBatchedStatements=true
jdbc.driverClass=com.mysql.cj.jdbc.Driver
jdbc.userName=root
jdbc.password=root
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
</configuration>
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:mvc="http://www.springframework.org/schema/mvc"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/context https://www.springframework.org/schema/context/spring-context.xsd http://www.springframework.org/schema/mvc https://www.springframework.org/schema/mvc/spring-mvc.xsd">
<!-- 1.配置扫描包 -->
<context:component-scan base-package="com.itbluebox" use-default-filters="false">
<context:include-filter type="annotation" expression="org.springframework.stereotype.Controller"/>
<context:include-filter type="annotation" 以上是关于精通系列)安装+基本使用+项目创建+项目部署+文件操作+依赖管理+插件使用的主要内容,如果未能解决你的问题,请参考以下文章
精通系列)安装+基本使用+项目创建+项目部署+文件操作+依赖管理+插件使用
精通系列)安装+基本使用+项目创建+项目部署+文件操作+依赖管理+插件使用
精通系列)创建 Springboot 项目+基于 ssm 多模块项目案例+微服务实战
精通系列)创建 Springboot 项目+基于 ssm 多模块项目案例+微服务实战
精通系列)创建 Springboot 项目+基于 ssm 多模块项目案例+微服务实战
Java之Spring Boot入门到精通,Spring Boot项目部署jar包方式,war包方式(一篇文章精通系列)