0
点赞
收藏
分享

微信扫一扫

gradle--task

承蒙不弃 2022-03-23 阅读 46



简介

任务是最小的工作单元,每个任务由动作和任务依赖组成,对应类 org.gradle.api.Task

实例

build.gradle

ext {
guestName='Bowen'
}

task hello << {
println guestName
println "hello, $guestName"
}

 命令行或者Idea执行:gradle hello -q

运行结果

Bowen
hello, Bowen

jar

简介

jar是任务,用于组装 JAR 文件。

实例1:最简单的grable打包

打出来的Jar包中,只包含了自己编写的代码编译成的Class文件。其它依赖的Jar包中的类,不在其中。

1.Idea创建普通gradle工程:Idea项目系列--创建gradle工程_feiying0canglang的博客-

2.在src/main/java下新建org.example.a.Demo.java,内容为:

package org.example.a;

public class Demo {
public static void main(String[] args) {
System.out.println("This is main");
}
}

4.修改build.gradle

plugins {
id 'java'
}

group 'com.example'
version '1.0-SNAPSHOT'

sourceCompatibility = 1.8

jar {
manifest {
attributes "Main-Class": "org.example.a.Demo"
}
}

4.执行打包操作

法1:直接点gradle的build按钮

gradle--task_java

法2:执行gradle jar命令

gradle--task_jar包_02

上边第3步执行完之后,会在项目路径的build\libs生成test_gradle-1.0-SNAPSHOT.jar

解压test_gradle-1.0-SNAPSHOT.jar:

gradle--task_java_03

若build.gradle这样写:

plugins {
id 'java'
}

group 'com.example'
version '1.0-SNAPSHOT'

sourceCompatibility = 1.8

jar {
manifest {
attributes "Main-Class": "org.example.a.Demo"
attributes 'Implementation-Title': 'Gradle Quickstart', 'Implementation-Version': version
}
}

生成的MANIFEST.MF结果:

gradle--task_jar_04

 因为java插件已有jar任务,上边两种写法其实只是修改了jar任务,若这样写build.gradle

plugins {
id 'java'
}

group 'com.example'
version '1.0-SNAPSHOT'

sourceCompatibility = 1.8

 生成的MANIFEST.MF结果:

gradle--task_java_05

4.测试结果

执行java -jar test_gradle-1.0-SNAPSHOT.jar,运行结果:

This is main

实例2:将第三方类打包进去

将第三方类也打包进去的方法

  1. 引用application插件,通过distTar或distZip打包。这样生成的包里不仅包含了自己项目中写的源码编辑成的jar包,还包括gradle中配置依赖的jar包,同时还生成了shell和bat脚本,通过脚本,可以直接运行我们的程序。
  2. 打jar包,直接依赖的第三方类库中的类,一起打包到我们的jar中。(本例采用此法)

build.gradle

jar {
manifestContentCharset 'utf-8'
metadataCharset 'utf-8'
manifest {
attributes "Main-Class": "cn.buddie.GradleTest"
}
from {
configurations.compile.collect { it.isDirectory() ? it : zipTree(it) }
}
}

也可以直接用java -jar xxx.jar运行

实例3:单jar包与tar包都生成

        如果领导说,你即需要提供单个的jar,又需要提供tar包,怎么办呢?因为修改了task jar,而task distTar是依赖于task jar。这样的后果就是打出来的tar包中,已经包含了所有你依赖的第三方jar包。同时,你自己项目打出的jar包中,又包含了这些第三方jar包中的类。也就是所有第三方的类,都重复了!

解决方案为:增加参数,让task jar根据参数来决定是否将第三方依赖类打入自己的jar包。

jar {
manifestContentCharset 'utf-8'
metadataCharset 'utf-8'
manifest {
attributes "Main-Class": "cn.buddie.GradleTest"
}
if (project.hasProperty("allInOne")) {
from {
configurations.compile.collect { it.isDirectory() ? it : zipTree(it) }
}
}
}

        增加了一个“allInOne”的参数,如果不指定参数,就不会将第三方依赖类打入jar包。这样在执行task distTar时,不指定参数,打出来的tar中,第三方依赖类就只有一份。而在需要所有类在一个Jar包中的Jar文件时,可以使用参数打包

gradle jar -PallInOne

其他网址

Gradle打可运行Jar包(包含依赖第三方库中的类) - buddie的个人空间



举报

相关推荐

0 条评论