使用maven-publish插件发布Android工件(kts)

本文参考 Android Developers 相关文档(源地址).


在项目模块化的过程中, 各个模块单独进行开发, 最终在上层模块引入.
为了引入方便和版本管理, 通常会使用 maven 来管理各个底层模块.

如果你的项目是使用 Gradle 构建的, 那么 Gradle 提供了一个很方便的插件用于发布模块工件: maven-publish , 我们参考 Android Developer 的说明, 可以很快速的在使用 Groovy 的 Gradle 中实现发布. 不过遗憾的是官方文档中没有提供使用 kotlin-kts 相关的指引. 最新的官方文档已提供配置实例, 请参考官方文档)!

在研究后整理了以下关于发布 library 为 Maven 工件的配置, 请添加到 Library Module 的 build.gradle.ktx 中:

plugins {
    id("com.android.library")
    id("maven-publish") // 添加插件
    ...
}

// 创建一个task来发布源码
tasks.register<Jar>("sourcesJar") {
    archiveClassifier.set("sources")
    val sources = android.sourceSets.map { set -> set.java.getSourceFiles() }
    from(sources)
}

afterEvaluate {
    publishing {
        repositories {
            maven {
                // isAllowInsecureProtocol = true // 如果Maven仓库仅支持http协议, 请打开此注释
                url = uri("https://your-repository") // 请填入你的仓库地址
                authentication {
                    create<BasicAuthentication>("basic")
                }
                credentials {
                    username = "your-username" // 请填入你的用户名
                    password = "your-password" // 请填入你的密码
                }
            }
        }

        publications {
            create<MavenPublication>("product") {
                from(components["release"])
                groupId = "your-group-id" // 请填入你的组件名
                artifactId = "your-artifact-id" // 请填入你的工件名
                version = "your-version" // 请填入工件的版本名
                artifact(tasks["sourcesJar"]) // 打包源码到工件中

                pom {
                    name.set("name") // (可选)为工件取一个名字
                    url.set("https://xxx") // (可选)网站地址
                    developers {
                        developer {
                            name.set("name") // (可选)开发者名称
                            email.set("email") // (可选)开发者邮箱
                        }
                    }
                }
            }
        }
    }
}

添加完配置之后, 可以执行以下 gradle task 发布工件(假设 Module 名称为 lib):
gradle clean :lib:build :lib:sourcesJar :lib:publish

如果在终端中使用 gradle-wrapper , 则可以使用:

  • MacOS/Linux: ./gradlew clean :lib:build :lib:sourcesJar :lib:publish
  • Windows: gradlew.bat clean :lib:build :lib:sourcesJar :lib:publish

近期升级 AGP 到 7.1.2 时发现出现了以下提示:

Software Components will not be created automatically for Maven publishing from Android Gradle Plugin 8.0. To opt-in to the future behavior, set the Gradle property android.disableAutomaticComponentCreation=true in the gradle.properties file or use the new publishing DSL.

估计在 AGP 8.0 版本之后上述的方法会失效, 到时候再看看有没有相关文档补充~


更新: 关于适配新版 AGP 的说明:

由于前述末尾中的提示让人烦心, 所以看了一下资料更新了一下发布功能:

更新步骤:

  1. 在项目的 gradle.properties 中添加一下配置:

    android.disableAutomaticComponentCreation=true
    
  2. 在 Library Module 中的 build.gradle.kts 文件中补充:

    android {
        ...
        publishing {
            singleVariant("release") {
                withSourcesJar()
            }
        }
    }
    
  3. 因为第二步中已经配置了发布源码, 所以可以将前述中添加的打包源码的 task(sourcesJar) 给移除掉;

  4. 修改发布逻辑:

    afterEvaluate {
        publishing {
            repositories {
                maven {
                    // isAllowInsecureProtocol = true // 如果Maven仓库仅支持http协议, 请打开此注释
                    url = uri("https://your-repository") // 请填入你的仓库地址
                    authentication {
                        create<BasicAuthentication>("basic")
                    }
                    credentials {
                        username = "your-username" // 请填入你的用户名
                        password = "your-password" // 请填入你的密码
                    }
                }
            }
    
            publications {
                create<MavenPublication>("release") {
                    from(components["release"])
                    groupId = "your-group-id" // 请填入你的组件名
                    artifactId = "your-artifact-id" // 请填入你的工件名
                    version = "your-version" // 请填入工件的版本名
    
                    pom {
                        name.set("name") // (可选)为工件取一个名字
                        url.set("https://xxx") // (可选)网站地址
                        developers {
                            developer {
                                name.set("name") // (可选)开发者名称
                                email.set("email") // (可选)开发者邮箱
                            }
                        }
                    }
                }
            }
        }
    }
    
  5. 完成.



作者:youthyJ
链接:https://www.jianshu.com/p/7b6d59942a4f
来源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
m-publish是一个Gradle插件,用于将本地library发布到Apache Maven仓库。通过使用插件,我们可以将*.aar、*.jar等library发布到仓库中,并通过gradle或者maven进行远程依赖使用。 要使用maven-publish插件,需要在build.gradle中声明插件,并在publishing{}块中进行配置。首先,通过在plugins{}块中添加id 'maven-publish'来声明插件。然后,在publishing{}块中,可以配置group和version属性,以及定义要发布的publication和repository。 例如,通过components.java来指定要发布的library,使用mavenLocal()来指定要发布到的仓库。可以根据需要添加更多的publication和repository配置。 maven-publish插件提供了一些任务,如generatePomFileForPubNamePublication用于创建需要发布的POM文件,并填充一些已知的元数据,例如项目名称、项目版本和依赖项。publishPubNamePublicationToRepoNameRepository用于将指定publication发布到指定repository。publishPubNamePublicationToMavenLocal用于将指定publication发布复制到本地Maven缓存,包括POM文件和其他元数据。 此外,还有一些其他任务,如publish将所有定义的publication发布到所有定义的存储库的聚合任务,而publishToMavenLocal将所有定义的publication复制到本地Maven库中,包括它们的元数据。 例如,如果我们有一个名为myLibrary的publication,并将其发布mavenLocal()仓库,我们可以运行命令publishPubNamePublicationToMavenLocal来实现。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值