美文网首页Android
手把手教你发布自己的开源库到jcenter

手把手教你发布自己的开源库到jcenter

作者: 猪_队友 | 来源:发表于2018-07-28 20:58 被阅读247次

    本文由玉刚说写作平台提供写作赞助,版权归玉刚说微信公众号所有
    原作者:Mr.s(猪_队友)
    版权声明:未经玉刚说许可,不得以任何形式转载

    最熟悉的陌生人

    想必大家都用过这样的或者那样的依赖吧。

        compile 'com.android.support:support-v4:24.2.1'
        compile 'com.google.code.gson:gson:2.7'
        compile 'com.umeng.analytics:analytics:6.1.4'
    

    有谷歌自己家的,还有第三方的比如友盟等等,我们在用的时候会感到极度的方便。不用再像以前eclipse时期需要把library下载下来再进行处理了。只需要一行代码,就可以得到我们想要的。

    有时候感觉这种依赖离我们自己很远,感觉这都是大神们的专属,感觉这些很是高级,所以会感觉很陌生。其实说白了,就和你上传到github一个效果,就是一个仓库,我们把我们的Library放上去就可以了。本质上来说是超级简单的。那我就手把手教你发布自己的开源库到Jcenter,让别人也用用咱们的依赖库,面试的时候也可以吹吹牛X。忽悠忽悠面试官。简单拿高薪,赢取白富美。(醒醒,醒醒,兄弟)

    小葵花课堂开课了

    很多人大概都会有这几个疑惑。

    1、什么是Maven
    2、什么是Jcenter
    3、上面这哥俩啥关系

    先讲一个小故事

    AndroidStudio刚开始的时候,是选择Maven Central作为默认仓库,但是由于Maven Central对开发者不太友好,上传library的难度比较大,而且还有安全上的一些问题。AndroidStudio就决定把这哥们开除,找来了一个叫Jcenter的新伙计。把默认的仓库替换成Jcenter

    新伙计的优点:
    • 下载更快(Jcenter通过CDN发送library
    • 仓库更大更全(Jcenter是全世界最大的Java仓库)
    • 操作更简单,界面更友好(上传Library傻瓜式操作)
    • 一键上传到 Maven Central(这个功能厉害吧,直接通过Jcenter把项目同步到Maven Central,避免了Maven Central难度大的问题)

    我们在builde.grade(Project:project)中可以看到仓库的默认配置。

     repositories {
            jcenter()
        }
    

    通过上面的小故事,然后我再解答一下上面的四个问题。

    解:

    1、什么是Maven

    Maven 是专门用于构建和管理Java相关项目的工具。这里是官方介绍

    题外话:

    Java世界中主要有三大构建工具:Ant、Maven和Gradle。经过这几年的发展,Ant差不多已经销声匿迹了、Maven也差不多也快黄了,咱们的Gradle现在可是如日中天。

    2、什么是Jcenter

    是由JFrog公司提供的Bintray中的Java仓库。它是当前世界上最大的Java和Android开源软件构件仓库。 所有内容都通过内容分发网络(CDN)使用加密https连接获取。JCenter是Goovy Grape内的默认仓库,Gradle内建支持(jcenter()仓库),非常易于在其他构建工具内进行配置。JCenter相比MavenCenter构件更多,性能也更好。

    3、上面这哥俩啥关系


    image.png

    Jcenter里支持Maven,也支持Gradle。说白了我是代码仓库,支持多种构建工具。你上传的Library这几个工具我都支持了,想怎么用你自己选择。总结说来 是代码仓库 和构造工具的关系。

    物料:

    Library工程(必须)
    Bintray账号(必须)
    github账号(非必须)

    NO.1--Library工程

    首先我们要创建一个Library工程。然后给一个高大上的名字。比如FireworkView:


    image.png
    image.png

    我这里这个Library的功能是给EditText 添加烟花效果(很简单的一个功能)

    NO.2--Bintray账号

    前提:科学上网 咳咳咳!你懂得!

    我们需要注册一个 Bintray账号。

    这里我们要说明一下,一定要点击个人这个链接,官网的注册链接只能注册企业用户,坑坑坑~~~


    image.png

    我们可以直接注册,可以用谷歌账号或者github账号,直接关联注册,建议大家用github账号进行关联注册。这样会很方便。当然也是有坑的,如果我们的github账号设置的邮箱是QQ邮箱,可能就有点碉堡了,貌似人家不认。所以邮箱最好用谷歌邮箱。当然我们独立注册Bintray,登录之后也可以进行第三方账号的绑定,这个和微信登录一样一样的。

    注册成功之后,我们要创建一个Maven仓库。


    image.png

    点击创建


    image.png
    Type选Maven,Default Licenses选Apache-2.0协议,Description是项目描述。
    注意:Name可以写项目名或者其他含义的名字,之后配置需要用到这个Name。

    好到此为止,我们需要的必要材料都准备齐了。

    NO.3--配置build.gradle

    1、builde.grade(Project:project)

    buildscript {
        repositories {
            jcenter()
        }
    //  dependencies表明项目依赖对应版本的Gradle构建工具
        dependencies {
           classpath 'com.android.tools.build:gradle:3.0.0'
      
            //加上这两行
            classpath 'com.github.dcendents:android-maven-gradle-plugin:2.1'
            classpath 'com.jfrog.bintray.gradle:gradle-bintray-plugin:1.7.3'
          
        }
    }
    
    allprojects {
        repositories {
            jcenter()
        }
    
    }
    
    

    至于最新版本号,大家可以去官网自行更改

    2、builde.grade(Module:XXX)

    添加apply plugin

    //  apply plugin表明应用的插件的类型,
    apply plugin: 'com.android.library'
    
    //添加这两行 
    apply plugin: 'com.github.dcendents.android-maven'
    apply plugin: 'com.jfrog.bintray'
    android {
        compileSdkVersion 26
    
        lintOptions {
            abortOnError false
        }
    
        defaultConfig {
            minSdkVersion 16
            targetSdkVersion 26
            versionCode 1
            versionName "1.0"
    
    
        }
    
        buildTypes {
            release {
                minifyEnabled false
                proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
            }
        }
    
    }
    
    dependencies {
        implementation fileTree(dir: 'libs', include: ['*.jar'])
    
    }
    
    //项目主页
    def siteUrl = 'https://github.com/shishaoyan/FireworksView'
    //项目的git地址
    def gitUrl = 'https://github.com/shishaoyan/FireworksView.git'
    //发布到JCenter上的项目名字
    def libName = "FireworksView"
    
    //发布到组织名称名字,必须填写 
    //(com.ssy.fireworkstextview)这样写是不好的,项目名会拼上去
    //我手欠然后最后就是这样了,大家引以为戒
    //compile 'com.ssy.fireworkstextview:fireworkstextview:1.0.0'
    group = "com.ssy"
    // 版本号,下次更新是只需要更改版本号即可
    version = "1.0.0"
    //上面配置后上传至JCenter后的编译路径是这样的: compile 'me.songning.CircleView:library:1.0.0'
    
    //生成源文件
    task sourcesJar(type: Jar) {
        from android.sourceSets.main.java.srcDirs
        classifier = 'sources'
    }
    
    //生成Javadoc文档
    task javadoc(type: Javadoc) {
        source = android.sourceSets.main.java.srcDirs
        classpath += project.files(android.getBootClasspath().join(File.pathSeparator))
    }
    
    //文档打包成jar
    task javadocJar(type: Jar, dependsOn: javadoc) {
        classifier = 'javadoc'
        from javadoc.destinationDir
    }
    
    //拷贝javadoc文件
    task copyDoc(type: Copy) {
        from "${buildDir}/docs/"
        into "docs"
    }
    
    //上传到JCenter所需要的源码文件
    artifacts {
        archives javadocJar
        archives sourcesJar
    }
    
    // 配置maven库,生成POM.xml文件
    install {
        repositories.mavenInstaller {
            // This generates POM.xml with proper parameters
            pom {
                project {
                    packaging 'aar'
                    //项目描述,随意填
                    name 'Input text with fireworks.'
                    url siteUrl
                    licenses {
                        license {
                            //开源协议
                            name 'The Apache Software License, Version 2.0'
                            url 'http://www.apache.org/licenses/LICENSE-2.0.txt'
                        }
                    }
                    developers {
                        developer {
                            //开发者的个人信息
                            id 'baidianxiao'
                            name 'ShiShaoYan'
                            email 'baidianxiao@gmail.com'
                        }
                    }
                    scm {
                        connection gitUrl
                        developerConnection gitUrl
                        url siteUrl
                    }
                }
            }
        }
    }
    
    //上传到JCenter
    Properties properties = new Properties()
    properties.load(project.rootProject.file('local.properties').newDataInputStream())
    
    bintray {
        user = properties.getProperty("bintray.user")    //读取 local.properties 文件里面的 bintray.user
        key = properties.getProperty("bintray.apikey")   //读取 local.properties 文件里面的 bintray.apikey
        configurations = ['archives']
        pkg {
            //注意:这里的repo值必须要和你创建Maven仓库的时候的名字一样
            repo = "ssy"
            //发布到JCenter上的项目名字
            name = libName
            //项目描述
            desc = 'Input text with fireworks'
            websiteUrl = siteUrl
            vcsUrl = gitUrl
            licenses = ["Apache-2.0"]
            publish = true
        }
    }
    
    javadoc {
        options{
            //如果你的项目里面有中文注释的话,必须将格式设置为UTF-8,不然会出现乱码
            encoding "UTF-8"
            charSet 'UTF-8'
            author true
            version true
            links "http://docs.oracle.com/javase/7/docs/api"
        }
    }
    

    3、local.properties

    将user和key写到这个文件之中。

    ndk.dir=/Users/shishaoyan/Library/Android/sdk/ndk-bundle
    sdk.dir=/Users/shishaoyan/Library/Android/sdk
    ##下面这两个
    bintray.apikey=93200ffcf836**********c8e78425e9cf9967a
    bintray.user=baidianxiao
    
    image.png

    然后点击Edit。


    image.png
    image.png

    NO.4--执行命令

    1、打开Android Studio底部工具栏的Terminal,输入命令:

    windows:

    gradlew install
    

    mac:

    ./gradlew install
    
    image.png

    BUILD SUCCESSFUL说明执行成功。

    2、上传到Bintray。

    windows:

     gradlew bintrayUpload
    

    mac:

     ./gradlew bintrayUpload
    
    image.png

    我这里因为网络的原因,失败了一次,然后科学上网了一下,就可以了。我们看到我们已经长传成功了,点击我们的Respository。


    image.png

    OK,完美,成功了吗?


    image.png

    再点进去。


    image.png

    我们发现我们想要的东西终于出来了。

    compile 'com.ssy:fireworkstextview:1.0.0'
    

    我们迫不及待的要加入我们的项目引用一下了,且慢,你还没有发布呢?纳尼?看右边的Add to JCenter按钮。对需要发布。发布成功后才可以让大家来使用。直接点击Send发送就可以了。


    image.png image.png

    最后我们需要等待几个小时,也可能是一两天,因为时差的原因和别的原因都可能导致慢一些,我的大概是一天半的时间。

    //这两个都可以使用,但是存在命名规范的问题
    //前缀 com.ssy.fireworkstextview 多余的失误
    compile 'com.ssy.fireworkstextview:fireworkstextview:1.0.0'
    //Library命名单词错误的失误
    compile 'com.ssy:fireworkstextview:1.0.0'
    

    不知道大家有没有发现了我的一个错误:fireworkstextview这个单词是我创建项目的时候打错的,本来应该是FireworksView。


    image.png

    我们在配置的时候并没有再出现这个词而是用的FireworksView,那么从这个错误中我们会知道,冒号后面的名字是项目名字。我们设置libName作用的地方如下图所示。而不是我们冒号后的名字。所以命名一定要一致。

    //发布到JCenter上的项目名字
    def libName = "FireworksView"
    
    image.png

    坑总是意外操作的时候出现的,趟过坑之后就是一片坦途了。

    终于把步骤全部走完了。我们感觉貌似有点麻烦啊。有没有另外一种方式呢?答案是有的。

    1、新建一个仓库


    image.png

    2、我们可以看到Import from GitHub (前提是你已经关联Github账号,按步骤来就可以了很简单)直接可以引用Public的项目,私有的是需要Bintray账号付费升级的。


    image.png

    3、我们选择我们的项目(我这里随便选了一个)

    image.png

    4、看到这里,是不是要赶紧去发布了呢?


    image.png

    5、懵逼了,为啥是空的呢


    image.png

    这是因为我们只是import了github的项目信息,我们真正需要的四个文件并没有别上传,所以我们需要把这四个文件上传,也就是我们之前配置所生成的文件。
    具体文档可以看这个https://www.jfrog.com/confluence/display/BT/Manually+Uploading+Files+to+a+Version

    //生成源文件
        task sourcesJar(type: Jar) {
            from android.sourceSets.main.java.srcDirs
            classifier = 'sources'
        }
    //生成Javadoc文档
        task javadoc(type: Javadoc) {
            source = android.sourceSets.main.java.srcDirs
            classpath += project.files(android.getBootClasspath().join(File.pathSeparator))
        }
    
    
    //文档打包成jar
        task javadocJar(type: Jar, dependsOn: javadoc) {
            classifier = 'javadoc'
            from javadoc.destinationDir
        }
    // 配置maven库,生成POM.xml文件
        install {
            repositories.mavenInstaller {
                // This generates POM.xml with proper parameters
                pom {
                    project {
                        packaging 'aar'
                        //项目描述,随意填
                        name 'Input text with fireworks.'
                        url siteUrl
                        licenses {
                            license {
                                //开源协议
                                name 'The Apache Software License, Version 2.0'
                                url 'http://www.apache.org/licenses/LICENSE-2.0.txt'
                            }
                        }
                        developers {
                            developer {
                                //开发者的个人信息
                                id 'baidianxiao'
                                name 'ShiShaoYan'
                                email 'baidianxiao@gmail.com'
                            }
                        }
                        scm {
                            connection gitUrl
                            developerConnection gitUrl
                            url siteUrl
                        }
                    }
                }
            }
        }
    
    

    6、创建一个新的版本号


    image.png

    7、上传相关文件


    image.png

    8、然后就有了Maven build setting 就可以add to Jcenter 了


    image.png

    总结:

    1、全代码配置,一劳永逸,其实也没有那么麻烦,每行代码都有它的含义,以后别的项目再用的话只需要修改变得地方就可以,别的地方都可以复用。

    2、手动界面操作,github导入,在一定程度上减少了代码的配置,但是还是需要配置生成文件的代码,不过有很多坑,需要看帮助文档才能趟过去。

    从坑少的角度来看,还是方案一:全代码配置。减少了错误的发生和一些莫名其妙的问题,虽然手动界面操作很直观,但是坑不少。所以全代码配置,大家都轻松。

    其实就是这么简单,没有我们想的那么难。当然,大家肯定会遇到一些莫名其妙的坑,有坑的同学可以看看这篇文章Android 发布项目到 JCenter 遇到的各种坑。我遇到了java 10 .0.1 区分不出来版本号的问题,无奈只能JDK降级,换了8的,解决了问题。

    image.png

    备注:

    我的项目地址https://github.com/shishaoyan/FireworksView还是不会配置的同学可以参考一下这个。

    大家如果觉得有帮助的话,可以点个关注,告诉我大家想要深入探究哪些问题,希望看到哪方面的文章,我可以免费给你写专题文章。。或者私信沟通都可以。。。
    希望大家多多支持。。你的一个关注,是我坚持的最大动力。。

    参考文章:

    一步一步教你在JCenter发布开源库

    相关文章

      网友评论

        本文标题:手把手教你发布自己的开源库到jcenter

        本文链接:https://www.haomeiwen.com/subject/zgtomftx.html