Gradle生成Jar的两种方式

1.不可执行的Jar

        方式1:在控制台执行gradle  build

                   
        方式2鼠标选择Gradle->Tasks->build->jar

                        

2.可执行Jar

方式1:将依赖Jar放入lib文件夹(一般项目和SpringBoot都可以)

task copyDependencies(type: Copy) {
    from configurations.runtime
    into 'build/libs/lib'
}
jar.dependsOn(copyDependencies)
jar {
    manifest {
        attributes "Implementation-Title": project.name
        attributes "Implementation-Version": '1.0.0'
        attributes 'Main-Class': 'Test'
    }
    if (!configurations.runtime.isEmpty()) {
        manifest.attributes('Class-Path': '. lib/' + configurations.runtime.collect { it.name }.join(' lib/'))
    }
}

或者 

jar {
    String someString = ''
    configurations.runtime.each {someString = someString + " lib//"+it.name}
    manifest {
        attributes 'Main-Class': 'Program'
        attributes 'Class-Path': someString
    }
}
//清除上次的编译过的文件
task clearPj(type:Delete){
    delete 'build','target'
}
task copyJar(type:Copy){
    from configurations.runtime
    into ('build/libs/lib')
}
//把JAR复制到目标目录
task release(type: Copy,dependsOn: [build,copyJar]) {
// from 'conf'
// into ('build/libs/eachend/conf') // 目标位置
}

展开右侧的Gradle侧边栏,找到在other下可以看到clearPj,copyJar以及release,双击release即可打jar包(它默认会执行copyJar,就是把所有的第三方依赖包放到lib目录下)

方式2:依赖包会和代码生成一个jar包(非SpringBoot项目)

然后鼠标执行Gradle->Tasks->build->jar

或者控制台gradle build

或者控制台gradle jar

jar {
    archivesBaseName = 'MiniRPC'//基本的文件名
    archiveVersion = '0.0.3' //版本
    manifest { //配置jar文件的manifest
        attributes(
                "Manifest-Version": 1.0,
                'Main-Class': 'com.mirs.minirpc.App' //指定main方法所在的文件
        )
    }
 //打包依赖包
    from {
        (configurations.runtimeClasspath).collect {
            it.isDirectory() ? it : zipTree(it)
        }
    }
}

方式3:依赖包会和代码生成一个jar包(SpringBoot项目)

在build.gradle增加

plugins {
  id "org.springframework.boot" version "2.5.2"
}

或者

buildscript {
  repositories {
    maven { url 'http://maven.aliyun.com/nexus/content/groups/public/' 
    maven { url 'http://maven.aliyun.com/nexus/content/repositories/jcenter' }
    maven {
      url "https://plugins.gradle.org/m2/"
    }
  }
  dependencies {
    classpath "org.springframework.boot:spring-boot-gradle-plugin:2.5.2"
  }
}

apply plugin: "org.springframework.boot"

然后鼠标执行Task->build->bootJar

 

或者控制台执行gradle bootJar

注意使用gadle的版本

参考:https://plugins.gradle.org/plugin/org.springframework.boot#groovy-usage

https://docs.spring.io/spring-boot/docs/2.5.2/gradle-plugin/reference/htmlsingle/#getting-started

  • 7
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要将 Gradle 项目打包成依赖包,你可以使用 Gradle 的 `maven-publish` 插件或者 `java-library` 插件。下面是两种方法的示例: #### 方法一:使用 maven-publish 插件 1. 在项目的 `build.gradle` 文件中添加以下内容: ```groovy plugins { id 'java' id 'maven-publish' } group = 'com.example' // 替换为你的项目组织名 version = '1.0.0' // 替换为你的项目版本号 publishing { publications { maven(MavenPublication) { from components.java } } repositories { maven { url "file://${project.buildDir}/repo" // 替换为你想要发布到的本地仓库路径 } } } ``` 2. 执行以下命令来打包并发布依赖包: ```shell gradle publish ``` 依赖包将会被发布到指定的本地仓库路径中。 #### 方法二:使用 java-library 插件 1. 在项目的 `build.gradle` 文件中添加以下内容: ```groovy plugins { id 'java-library' } group = 'com.example' // 替换为你的项目组织名 version = '1.0.0' // 替换为你的项目版本号 repositories { mavenLocal() } dependencies { // 添加项目的依赖关系 } task sourcesJar(type: Jar) { from sourceSets.main.allJava archiveClassifier.set('sources') } task javadocJar(type: Jar) { from javadoc.destinationDir archiveClassifier.set('javadoc') } artifacts { archives sourcesJar archives javadocJar } ``` 2. 执行以下命令来打包依赖包: ```shell gradle build ``` 生成的依赖包将会位于 `build/libs` 目录下。 这两种方法都可以将 Gradle 项目打包成依赖包,你可以选择适合你项目需求的方法来实现。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值