Android程序员

Bintray项目发布-手动

2019-01-19  本文已影响0人  十思叶

前言

本文主要说明如何生成项目构件,并手动上传构件文件到Bintray平台,最后发布到JCenter仓库这一流程。

发布流程。参考上一篇文章,完整发布流程如下:

  1. 准备工作。定义参数;准备本地待发布项目;配置Bintray平台账号、仓库、Package、版本。
  2. 生成构件文件。本地生成待发布的构件文件(包括POM文件)。
  3. 发布到Bintray。上传和发布本地构件文件到Bintray平台。
  4. 发布到JCenter。发布Bintray平台上的项目到JCenter。

源码地址。本文涉及到的nicelogger项目Github地址:https://github.com/zhangliangnbu/nice-logger


准备工作

参考上一篇文章,如果已经做了,可以跳过。默认你已经有了一个本地项目,已经创建了Bintray平台账号和Maven仓库。

定义参数

准备本地项目。略。

配置Bintray平台。根据参数创建Package和版本。


生成构件

生成需要上传到Maven库的四个文件:

生成nicelogger-0.0.1.aar文件

niceloggerbuild.gradle最后中添加如下代码,用于重命名生成的aar文件:

// 定义pom文件参数
def groupIdDefined = "com.liang.android"
def artifactIdDefined = "nicelogger"
def versionDefined = "0.0.1"

// 重命名生成的arr文件
android.libraryVariants.all { variant ->
    variant.outputs.all { output ->
        if (outputFile != null && outputFileName.endsWith('.aar')) {
            outputFileName = "${artifactIdDefined}-${versionDefined}.aar"
        }
    }
}

执行./gradlew nicelogger:assembleRelease生成arr文件,位于library/build/outputs/aar/中。

生成nicelogger-0.0.1-sources.jar文件

接着在niceloggerbuild.gradle最后添加如下代码,建立生成所需文件的任务

// 生成Java源码文件
task sourcesJar(type: Jar) {
    from android.sourceSets.main.java.srcDirs
    baseName = "${artifactIdDefined}-${versionDefined}"
    classifier = 'sources'
}

然后执行./gradlew nicelogger:sourcesJar,就可以生成Java源码文件,位于nicelogger/build/libs/中。

生成nicelogger-0.0.1-javadoc.jar文件

接着在niceloggerbuild.gradle最后添加如下代码,建立生成所需文件的任务

// 生成Javadoc文件
task javadoc(type: Javadoc) {
    failOnError false
    source = android.sourceSets.main.java.sourceFiles
    classpath += project.files(android.getBootClasspath().join(File.pathSeparator))
    classpath += configurations.compile
}
task javadocJar(type: Jar, dependsOn: javadoc) {
    baseName = "${artifactIdDefined}-${versionDefined}"
    classifier = 'javadoc'
    from javadoc.destinationDir
}

然后执行./gradlew nicelogger:javadocJar,就可以生成Javadoc文件,位于nicelogger/build/libs/中。

生成nicelogger-0.0.1.pom文件

有两种方式创建POM文件:

一,参考POM Reference手动创建POM文件,填入相关参数。

二,使用Gradle Maven Plugin生成POM,接着在niceloggerbuild.gradle最后中添加如下代码

// 生成pom文件
apply plugin: 'maven'

task createPom {
    doLast {
        pom {
            project {
                groupId "${groupIdDefined}"
                artifactId "${artifactIdDefined}"
                version "${versionDefined}"
                packaging "aar"
                licenses {
                    license {
                        name 'The Apache Software License, Version 2.0'
                        url 'http://www.apache.org/licenses/LICENSE-2.0.txt'
                    }
                }
            }
        }.writeTo("$libsDir/${artifactIdDefined}-${versionDefined}.pom")
    }
}

后执行./gradlew nicelogger:createPom,就可以生成所需的POM文件,位于nicelogger/build/libs/中,内容如下:

<?xml version="1.0" encoding="UTF-8"?>
<project xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd" xmlns="http://maven.apache.org/POM/4.0.0"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
  <modelVersion>4.0.0</modelVersion>
  <groupId>com.liang.android</groupId>
  <artifactId>nicelogger</artifactId>
  <version>0.0.1</version>
  <packaging>aar</packaging>
  <licenses>
    <license>
      <name>The Apache Software License, Version 2.0</name>
      <url>http://www.apache.org/licenses/LICENSE-2.0.txt</url>
    </license>
  </licenses>
</project>

生成四个文件后,可以把它们放在一个文件夹里,方面之后的上传操作。


发布到Bintray

上传文件

Target Repository Path为{groupId}/{artifactId}/{version},其中“.”都需要替换为“/”。

发布到Bintray仓库

上传文件完成后,会提示如何处理文件:“Discard”还是“Publish”。选择“Publish”,就会发布文件到Bintray平台的Maven仓库,这样我们就能解析,只不过要带上用户自己的仓库地址而已。

发布到Bintray仓库后,会自动生成maven-metadata.xml文件。

用户Bintray仓库地址。发布后的项目在https://dl.bintray.com/{username}/{repository_name}下可查看,我刚才发布的项目在https://dl.bintray.com/zhangliang/android/com/liang/android/nicelogger/

Bintray仓库依赖解析

Gradle项目使用nicelogger依赖方式如下:

一,添加仓库地址。

在需要此依赖的项目build.gradle配置仓库地址:

repositories {
    maven {
        url "https://dl.bintray.com/zhangliang/android"
    }
}

或工程目录build.gradle下添加配置:

allprojects {
    repositories {
        maven {
            url "https://dl.bintray.com/zhangliang/android"
        }
    }
}

二,添加依赖。在项目build.gradle配置依赖

dependencies {
    implementation 'com.liang.android:nicelogger:0.0.1'
}

发布到JCenter

进入nicelogger的package页面,点击“Add to JCenter”,进入下一页,点击“Send”即可。

发布到JCenter仓库需要审核,主要审核文件格式是否符合规范和以及名称是否唯一等,没有问题的话,一般一个工作日以内都会通过。通过后,可以直接用jcenter作为仓库地址,无需配置用户自己的Bintray仓库地址。

JCenter仓库地址。http://jcenter.bintray.com/{地址化的groupId}地址化的groupId即用“/”代替“.”。

具体详情请见用户指南发布到JCenter

可能遇到的问题

一,点击“Add to JCenter”报错:

Please fix the following before submitting a JCenter inclusion request: the POM is invalid or was uploaded to the wrong coordinates

我之前是因为文件名不一致才出现这个错误提示。必须为{artifactId}-{version}xxx等。

终于写完了一个完整的流程,O(∩_∩)O。


参考

  1. Bintray官网
  2. JCenter仓库
  3. JFrog用户指南

注:文章首发简书和我的个人博客永恒的码流


上一篇下一篇

猜你喜欢

热点阅读