首页 > 代码库 > [Gradle系列]Gradle发布module库到jcenter, 并构建自己的企业Maven私服

[Gradle系列]Gradle发布module库到jcenter, 并构建自己的企业Maven私服

Tamic 作者: http://blog.csdn.net/sk719887916

前言

andorid开发者经常会看到xx公司发布了xx项目,xx公司只提供了gradle配置路径我们就能轻松的使用它们的项目到自己的工程中:

譬如:

谷歌自身的库

compile ‘com.android.support:appcompat-v7:22.2.0‘

第三方库

compile ‘com.squareup.okhttp:okhttp:2.7.2‘

很多开发者看过之后羡慕不已, 想自己能不能也写一个自己的库让别人用(或者发布已有的本地modul库),或者当多模块开发时,为了进行版本协作,使用自己的maven库是势在必得的!

Maven

Apache Maven,是一个软件(特别是Java软件)项目管理及自动构建工具,由Apache软件基金会所提供。基于项目对象模型(缩写:POM)概念,Maven利用一个中央信息片断能管理一个项目的构建、报告和文档等步骤。
更多请点击:Maven

Maven package 是由所谓 POM(Project Object Model)所定义的文件包的一种输出特殊格式。

Maven仓库就是,就是放 Maven包的地方, 所以叫仓库。 这些仓库,可以是放在本地,也可以放在远程服务器上。 可以开放仓库,也可以加密公开的,提供别人下载使用!

一句大白话你就懂了:maven是类似android studio的构建工具, maven包是对于构建工具产出的格式,maven包类似是apk,maven仓库是apk应用市场一样!

Maven仓库

JCenter和MavenCentral

jcenter是由 bintray.com提供的Maven仓库存放的平台服务器,用户可以注册发布托管自己的开源maven包

Maven Central 是由sonatype.org 提供的发布的Maven服务平台。虽然Maven Central和jcenter都是标准的maven仓库服务器。

同样的仓库却毫无联系。 在jcenter上存在的开源库,可能 在Maven Central 上并不存在,反之亦然。 就类似豌豆荚和91助手都可以存在apk下载,但不一定都能搜到同一个应用一样, MavenCentral上发布maven包比发布到jcente有点复杂,当然我们可以将jcenter的包同步到MavenCenter

发布maven包

远程jcenter

Maven

一首先我们需要在jcenter注册一个账号 点我注册

技术分享

如果你有github直接可以用gitbub账户注册! 然后补充下资料信息!

接着登录成功后我们去获取这个账户的签名key,用来区分账户Id信息,先记录好自己的
key,后面会用到这个信息。

技术分享

创建moudle

  • 1 创建模块

    如果你是从零开始去写一个组件模块,就直接在as为你的app创建一个
    module, 如果已有请直接绕道到第三步。

技术分享
当创建好你的module是时候就会生成一个自己的library

接着可以在自己module配置gradle

技术分享

下面步骤请在自己的moulde中gradle中配置加入。
- 3 申明插件类型

     apply plugin: ‘com.github.dcendents.android-maven‘
     apply plugin: ‘com.jfrog.bintray‘
  • 4 配置maven包信息

    //版本号
    version = "1.0.0"
    //这是项目首页
    def siteUrl = ‘https://github.com/NeglectedByBoss/Novate‘
    //这是源码地址
    def gitUrl = ‘https://github.com/NeglectedByBoss/Novate.git‘
    // 包名,可以写公司的前缀
    group = "com.tamic.novate"
    
  • 5 定制输出格式信息

        install {
       repositories.mavenInstaller {
      // This generates POM.xml with proper parameters
     pom {
         //pom信息
         project {
          packaging ‘aar‘
         // Add your description here
          name ‘novate‘
          url siteUrl
         // Set your license
    licenses {
      //开源协议
       license {
         name ‘The Apache Software License, Version 2.0‘
          url ‘http://www.apache.org/licenses/LICENSE-2.0.txt‘
              }
             }
    developers {
      //开发者基本信息
        developer {
        id ‘tamic‘
        name ‘tamic‘
        email ‘xxxx@xxx.com‘
                  }
              }
    
         scm {
            connection gitUrl
            developerConnection gitUrl
            url siteUrl
             }
           }
       }
     }
    }
    
  • 6 输出资源

    task sourcesJar(type: Jar) {
    from android.sourceSets.main.java.srcDirs
      classifier = ‘sources‘
     }
     task javadoc(type: Javadoc) {
      source = android.sourceSets.main.java.srcDirs
      classpath += project.files(android.getBootClasspath   ().join(File.pathSeparator))
    }
    task javadocJar(type: Jar, dependsOn: javadoc) {
        classifier = ‘javadoc‘
       from javadoc.destinationDir
     }
     artifacts {
     archives javadocJar
     archives sourcesJar
     }
    
  • 7 配置账号

    这时候加入自己的账号和key,当然你不想加入到local配置中,也可以单独建个prpertites文件,设置git的忽略规则即可。

    技术分享

  • 8 申明编译类型

    在朱项目的gradle中加入下面申明

      buildscript {
      repositories {
      jcenter()
    
     }
     dependencies {
    classpath ‘com.android.tools.build:gradle:2.3.0‘
    //这里是依赖的插件类型路径,用最新的即可
     classpath ‘com.jfrog.bintray.gradle:gradle-bintray-plugin:1.4‘
     classpath ‘com.github.dcendents:android-maven-gradle-plugin:1.3‘
     }
    }
    

提交maven

当我们将项目build时候,as就会生成如下task

技术分享

双击即可,也可以在命令行输入 gradle brntaryUpload.

如果成功了,可以去预览我们项目,发现会有你发布的包了,我这里有四个项目,如果第一次用只显示一个,直接点击预览自己的Maven包 ,

技术分享

接着继续打开后发现maven包具体预览界面了,

技术分享

这时候需要add到仓库中心等管理员审核,如果第一次就会有addjcenter按钮,

技术分享

提交会打开一个申请页面,你填写评论就Okle ,中文也可以,等到一两小时,搜到系统发来的私信,就代表你的库成功了,这时候就有maven依赖地址生成了,我们可以直接拿来配置就可以了

技术分享

  • 9 使用mven包

    这个就不用多说了吧,心累!

问题总结

如果发现提示你javadoc不过,就关闭doc检查,

技术分享

如果发现编码出错,就指定utf-8

在module的gradle中加入

  javadoc {
options{
encoding "UTF-8"
charSet ‘UTF-8‘
author true
version true
links "http://docs.oracle.com/javase/7/docs/api"
}
}

tasks.withType(Javadoc) {
options.addStringOption(‘Xdoclint:none‘, ‘-quiet‘)
options.addStringOption(‘encoding‘, ‘UTF-8‘)
options.addStringOption(‘charSet‘, ‘UTF-8‘)
}

如果希望自己代码混淆请配置好相关规则,这里不再介绍了。

Maven Central

可能很多人还想发布到 Maven Central去,可以接着看,虽然长了点,请仔细耐心看完

  • 注册 sonatye 账户

    到 sonatype issue 页面,注册账号。

    技术分享

  • 创建 issue

    登陆之后,顶部有按钮,Created,下面是关键的条目

    Project: Community Support - Open Source Project Repository Hosting (OSSRH)
    Issue Type: New Project
    Group Id:就是你的包的 groupId

其他信息请加上,提交之后,大概两个工作日, 等系统给你分配了issue之后,就可以进行下面的工作了,这块可以参考 点击介绍

  • 上传包

    配置gradle

    整个结构,

    技术分享

    现在我们将红框内的task覆盖,具体如下

    ext {
      PROJ_GROUPID = ‘com.tamic.android‘
      PROJ_ARTIFACTID = ‘novate‘ //这是项目名字
       PROJ_VERSION_NAME = "1.0.0"//版本号
    
       POM_PACKAGING = ‘aar‘
    
      NEXUS_USERNAME = ‘注册的账号‘
      NEXUS_PASSWORD = ‘这是密码‘
      RELEASE_REPOSITORY_URL = ‘这里是sonatye配置好的线上路径‘
       SNAPSHOT_REPOSITORY_URL = ‘这里是在 sonatye配置好的snaphot路径‘
    

    }

    uploadArchives {
    
    repositories {
    mavenDeployer {
        snapshotRepository(url: SNAPSHOT_REPOSITORY_URL) {
            authentication(userName: NEXUS_USERNAME, password: NEXUS_PASSWORD)
        }
        repository(url: RELEASE_REPOSITORY_URL) {
            authentication(userName: NEXUS_USERNAME, password: NEXUS_PASSWORD)
        }
    
        pom.project {
            version PROJ_VERSION_NAME
            groupId PROJ_GROUPID
            artifactId PROJ_ARTIFACTID
            packaging ‘aar‘
    
         }
    
      }
    

    }

    当然密码可以加载jcenter公用的那个properties文件中,防止上传的代码git上,

    然后运行as命令,或点击下面这个task即可。

    技术分享

    发布maven包

    登陆 oss sonatype,登陆,选择左边栏里的 Staging Repositories, 然后点Close 按钮,sonatype 会做响应的 validation,通过的话,就可以点 Release 发布啦,如果不通过,就检查问题,先 Drop,并重新做 Staging 发布。

    检查包

    在 https://oss.sonatype.org/content/repositories/releases 可以看到你发布的包。

两者同步

如果你觉得这种方式比较麻烦,那么我们可以将JCenter的项目同步MavenCentral到上,

技术分享

搭建企业maven私服

在项目不端庞大情况下,可能你的项目依赖的module越来越多,这样对版本控制越来越难,大家就像都push到maven库上,但有不想公开自己的maven包,所以MavenCentral提供了自己的企业私服,Sonatype 提供了免费的 sonatype/nexus。

请忽略 作者: http://blog.csdn.net/sk719887916

下载安装 docker 镜像

  $ docker pull sonatype/nexus

开启服务镜像

  $ docker run -d -p 8081:8089 --name nexus sonatype/nexus:oss

访问服务器

因为的 docker-machine ip 是:192.168.99.100,于是可以通过在浏览器访问http://192.168.99.100:8089/ 这个 URL 来访问 sonatype 私服。
条件允许的可以在内网部署一台服务器,用来运行这个maven私服。甚至找运维可以创建自己的Maven域名

默认账户密码是:

  admin
 admin123

配置仓库

点击左侧 repository,会出现 repository 的列表,把其中的 Releases 的 Configutation->Access Setting-> Deploy Polocy 设置成 Allow Redeploy 使得可以重复发布包。

配置上传插件

因为使用了自己的私服 chrisbanes/gradle-mvn-push 插件,稍微改动,所有我们需要修改自己的maven私服repository URL 等,

关键设置

   ext {
PROJ_GROUPID = ‘com.tamic.android‘
PROJ_ARTIFACTID = ‘android_statSdk‘
PROJ_VERSION_NAME = "1.0.0"

POM_PACKAGING = ‘aar‘

NEXUS_USERNAME = ‘admin‘
NEXUS_PASSWORD = ‘admin123‘
RELEASE_REPOSITORY_URL = ‘修改为你配置的路径‘
SNAPSHOT_REPOSITORY_URL = ‘修改为你配置的路径‘
}

检测是否成功

上传成功之后,就可以在浏览器的http://192.168.99.100:8089/content/repositories/releases看到这个包。发现存在,说明已经成功了。

技术分享

使用

指定自己的mven仓库地址

技术分享
在root的gradle指定你的maven服务器路径就ok了,其他moudule配置和使用第三方库一样。

发布本地Maven

有时候你不想发布到自己公司的内网私服上,只想测试下本地打包机制,这时候随便找个mven包,反到电脑任意路径下。指定本地路径就ok了,下面三种可以随你选择

allprojects {
    repositories {
     //本机仓库
     mavenLocal()

    //内网maven仓库
    maven {  url "你的内网私服地址"  }
    maven {

        url "你的Maven路径"
    }
}

}

经验总结

  • 上传失败,返回400,可能是Configutation->Access Setting-> Deploy Polocy没设置好;返回401,可能是账号密码错误。

  • 如果出现失败,请检版本号是否一致,如果服务器存在的版本号会上传不了,请先删除就版本再上传,

  • 如果出现NOT found you moudle无法上传情况,请只保留一个android STUDIO,在点击上传task.

华丽结束

上面展示了两种发布maven包到仓库的方式,开发者可以自我去选择,maven不仅很好的解决了模块化开发是带来的版本控制问题,也方便了项目对依赖的旧版本回滚控制, 具体在使用的地方可以自己指定maven版本,这次介绍了怎么在gradle发布maven的姿势,下节在总结下在多模块情况下,开发者想用同一套代码,生成不同apk,设置可以选择不同资源打包的问题。 gradle多渠道和多版本打包相关的知识,期待你的关注!

Tamic : http://blog.csdn.net/sk719887916

<script type="text/javascript"> $(function () { $(‘pre.prettyprint code‘).each(function () { var lines = $(this).text().split(‘\n‘).length; var $numbering = $(‘
    ‘).addClass(‘pre-numbering‘).hide(); $(this).addClass(‘has-numbering‘).parent().append($numbering); for (i = 1; i <= lines; i++) { $numbering.append($(‘
  • ‘).text(i)); }; $numbering.fadeIn(1700); }); }); </script>

    [Gradle系列]Gradle发布module库到jcenter, 并构建自己的企业Maven私服