您的位置:首页 > 其它

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

2016-11-18 23:08 465 查看
Tamic 作者: http://blog.csdn.net/sk719887916/article/details/53224544

前言

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
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  gradle maven