用GitHub做自己的Maven 库

制作步骤:

  1. 配置属性
  2. 引用插件
  3. 打包
  4. 上传到gitHab
  5. 设置地址
  6. 引用到项目工程

我们做一个自定义控件为例,带清楚的EditText控件。
在工程新建一个module, clearedittext

《用GitHub做自己的Maven 库》 文件目录

1. 配置属性

在module 中添加属性配置文件 ,gradle.properties

POM_NAME=custom-view-clearedittext
POM_ARTIFACT_ID=custom-view-clearedittext
POM_PACKAGING=aar
VERSION_NAME=1.0.0-SNAPSHOT
VERSION_CODE=1
GROUP=com.yangyang.maven

POM_DESCRIPTION=
POM_URL=
POM_SCM_URL=
POM_SCM_CONNECTION=
POM_SCM_DEV_CONNECTION=
POM_LICENCE_NAME=The Apache Software License, Version 2.0
POM_LICENCE_URL=http://www.apache.org/licenses/LICENSE-2.0.txt
POM_LICENCE_DIST=repo
POM_DEVELOPER_ID=
POM_DEVELOPER_NAME=
RELEASE_REPOSITORY_URL=file:./MavenArr/release
SNAPSHOT_REPOSITORY_URL=file:./MavenArr/snapshots
  • 设置名称与id
    POM_NAME=custom-view-clearedittext
    POM_ARTIFACT_ID=custom-view-clearedittext
    POM_PACKAGING=aar
  • 设置版本号
    VERSION_NAME=1.0.0-SNAPSHOT
    VERSION_CODE=1
  • 设置组名称
    GROUP=com.yangyang.maven
  • 设置aar输入地址
    RELEASE_REPOSITORY_URL=file:./MavenArr/release
    SNAPSHOT_REPOSITORY_URL=file:./MavenArr/snapshots

2. 引用插件

在项目 中添加脚本文件 ,gradle-mvn-push.gradle

apply plugin: 'maven'
apply plugin: 'signing'

def isReleaseBuild() {
    return VERSION_NAME.contains("SNAPSHOT") == false
}

def getReleaseRepositoryUrl() {
    return hasProperty('RELEASE_REPOSITORY_URL') ? RELEASE_REPOSITORY_URL
            : "https://oss.sonatype.org/service/local/staging/deploy/maven2/"
}

def getSnapshotRepositoryUrl() {
    return hasProperty('SNAPSHOT_REPOSITORY_URL') ? SNAPSHOT_REPOSITORY_URL
            : "https://oss.sonatype.org/content/repositories/snapshots/"
}

def getRepositoryUsername() {
    return hasProperty('NEXUS_USERNAME') ? NEXUS_USERNAME : ""
}

def getRepositoryPassword() {
    return hasProperty('NEXUS_PASSWORD') ? NEXUS_PASSWORD : ""
}

afterEvaluate { project ->
    uploadArchives {
        repositories {
            mavenDeployer {
                beforeDeployment { MavenDeployment deployment -> signing.signPom(deployment) }

                pom.groupId = GROUP
                pom.artifactId = POM_ARTIFACT_ID
                pom.version = VERSION_NAME

                repository(url: getReleaseRepositoryUrl()) {
                    authentication(userName: getRepositoryUsername(), password: getRepositoryPassword())
                }
                snapshotRepository(url: getSnapshotRepositoryUrl()) {
                    authentication(userName: getRepositoryUsername(), password: getRepositoryPassword())
                }

                pom.project {
                    name POM_NAME
                    packaging POM_PACKAGING
                    description POM_DESCRIPTION
                    url POM_URL

                    scm {
                        url POM_SCM_URL
                        connection POM_SCM_CONNECTION
                        developerConnection POM_SCM_DEV_CONNECTION
                    }

                    licenses {
                        license {
                            name POM_LICENCE_NAME
                            url POM_LICENCE_URL
                            distribution POM_LICENCE_DIST
                        }
                    }

                    developers {
                        developer {
                            id POM_DEVELOPER_ID
                            name POM_DEVELOPER_NAME
                        }
                    }
                }
            }
        }
    }

    signing {
        required { isReleaseBuild() && gradle.taskGraph.hasTask("uploadArchives") }
        sign configurations.archives
    }

    task androidJavadocs(type: Javadoc) {
        source = android.sourceSets.main.java.srcDirs
        classpath += project.files(android.getBootClasspath().join(File.pathSeparator))
    }

    task androidJavadocsJar(type: Jar, dependsOn: androidJavadocs) {
        classifier = 'javadoc'
        from androidJavadocs.destinationDir
    }

    task androidSourcesJar(type: Jar) {
        classifier = 'sources'
        from android.sourceSets.main.java.sourceFiles
    }

    artifacts {
        archives androidSourcesJar
        archives androidJavadocsJar
    }
}
  • 在module 中引用插件脚本
  apply from: file('../gradle-mvn-push.gradle')

3. 打包

在控制台输入:gradlew uploadArchives -p clearedittext 命令打包 clearedittext自己的module名称
项目中生成的文件

《用GitHub做自己的Maven 库》 通过命令生成的文件

4. 上传到gitHab

把文件上传到自己的GitHab中。

5. 设置引用地址

在项目gradle文件中配置

allprojects {
    repositories {
        google()
        jcenter()

        //添加地址
        maven {
            url "https://github.com/yylxy/AndroidCustomMaven/raw/master/MavenArr/snapshots"
        }
    }
}

6. 引用到项目工程

 //引用远程版本
    implementation 'com.joyoung.smartrobot:custom-view-clearedittext:1.0.0-SNAPSHOT'

7. 注意事项

输入命令会检测一些规范,导致编译失败,可以项目中build.gradle文件添加

 tasks.getByPath(":clearedittext:androidJavadocs").enabled = false

有时版本更新不下来可能是Studio缓存问题,可以更改缓存配置:

 configurations.all {
    // 检查远程依赖是否存在更新
    resolutionStrategy.cacheChangingModulesFor 0, 'seconds'
    // 采用动态版本声明的依赖缓存
    resolutionStrategy.cacheDynamicVersionsFor 0, 'seconds'
}

以上希望对你有用,谢谢!

源码下载地址
参考原文

    原文作者:一束光线
    原文地址: https://www.jianshu.com/p/1214e92bb3d7
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞