先唠叨几句啊,由于公司私服已经搭好了我就不费那劲琢磨搭建私服的事了,直接开撸上传lib。下图是我放组件库的地方,本来想一个module拉出一个项目来维护,后来想想实在是麻烦,同时维护多个库就要down多个库下来,于是就统一管理了。当然统一维护module多了自然会影响编译的速度,可以在settings.gradle 里将不编译的module注释掉就可以了。现在就有图片选择、表情、输入框、星星、视频录制、裁切等七七八八个库,至于后面组件库多了可能会分类按类型拉出几个项目来管理,要不版本控制也是个麻烦事。目前就是升级一个module在git上打个tag标签。大家有啥好的建议欢迎留言哈。

Nexus是一个基于maven的仓库管理的社区项目.主要的使用场景就是可以在局域网搭建一个maven私服,用来部署第三方公共构件或者作为远程仓库在该局域网的一个代理.简单举几个例子就是:

1.第三方Jar包可以放在nexus上,项目可以直接通过Url和路径配置直接引用.方便进行统一管理.

2.同时有多个项目在开发的时候,一些共用基础模块可以单独抽取到nexus上,需要用的项目直接从nexus上拉取就行(基础模块的实现,维护和部署可以交给专门的人员,其他项目不用关心代码实现,这样也可以达到保证核心代码不泄露).

3.一些封闭开发的过程中开发机是不能上公网的,所以连接central repository和下载jar就比较麻烦,这时就可以用nexus搭建起来一个介于公网和局域网之间的桥梁.

接下来就简单介绍一下nexus的搭建以及在android项目中使用nexus的方式.

项目展示.png

发布Library到私服

我们就以functionbar这个组件库为例吧

配置nexus账户信息

因为Nexus相关参数是固定的,包含仓库地址、用户名和密码,从安全性考虑我们把这些参数写到gradle的Global配置中,目录是C:\Users(用户名).gradle\gradle.properties

NEXUS_USERNAME=username
NEXUS_PASSWORD=password
NEXUS_REPOSITORY_URL=http://xxx/nexus/repository/maven-releases/

配置pom参数

项目根目录下的gradle.properties中添加如下pom参数

//依赖库名称
POM_NAME=functionbar
//版本号
POM_VERSION=1.0.1
//类别
POM_ARTIFACTID=utils
//组id
POM_GROUPID=com.app
//打包类型
POM_PACKAGING=aar

引入gradle脚本

在library的build.gradle文件末尾加上如下引用,当然这个文件需要创建放到项目根路径,源码在脚本解读中

apply from: '../nexus_upload.gradle'

这个nexus_upload.gradle脚本包含生成java-source和java-doc,如果注释不完整可以注释掉脚本里的androidJavadocsJar调用,避免影响上传。

发布

双击右侧gradle task中的uploadArchives,编译并上传library

up.png

等待一会出现Success字样,证明已经上传成功

success.png

最后我们去Nexus上验证下,bingo!上传成功。


脚本解读

//依赖maven插件
apply plugin: 'maven'

task androidJavadocs(type: Javadoc) {
  options.encoding = "utf-8"
  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.srcDirs
}

artifacts {
  archives androidSourcesJar
  //如果项目javadoc不全会报错,可以注释掉
  archives androidJavadocsJar
}

uploadArchives {
  repositories {
    mavenDeployer {
      //仓库地址
      repository(url: NEXUS_REPOSITORY_URL) {
        //私服账户信息
        authentication(userName: NEXUS_USERNAME, password: NEXUS_PASSWORD)
      }
      //pom必需的参数
      pom.project {
        name POM_NAME
        version POM_VERSION
        artifactId POM_ARTIFACTID
        groupId POM_GROUPID
        packaging POM_PACKAGING
      }
    }
  }
}

使用私服上的Library

首先,要在项目的build.gradle里面声明私服的地址

allprojects {
  repositories {
    jcenter()
    mavenCentral()
    maven { url NEXUS_REPOSITORY_URL}
  }
}

然后就是我们最熟悉的在module的build.gradle文件中添加依赖,注意 groupId后面是:依赖库名称后面要加:和版本号,我就犯过引用是groupId后面写. 的错误。

compile 'com.app:functionbar:1.0.1

发布Plugin(插件)到私服

发布步骤是和library一样的只不过需要提一点,脚本信息需要做一些删减,只用到以下这些。

apply plugin: 'maven'
uploadArchives {
  repositories {
    mavenDeployer {
      //仓库地址
      repository(url: NEXUS_REPOSITORY_URL) {
        //私服账户信息
        authentication(userName: NEXUS_USERNAME, password: NEXUS_PASSWORD)
      }
      //pom必需的参数
      pom.project {
        name POM_NAME
        version POM_VERSION
        artifactId POM_ARTIFACTID
        groupId POM_GROUPID
        packaging POM_PACKAGING
      }
    }
  }
}

使用私服上的Plugin

首先,要在项目的build.gradle里面配置classpath引用,就拿经典的小刀举例吧

buildscript {

  repositories {
    jcenter()
    maven { url NEXUS_REPOSITORY_URL}
  }
  dependencies {
    classpath 'com.android.tools.build:gradle:2.2.0'
    classpath 'com.jakewharton:butterknife-gradle-plugin:8.8.1'
    ...
  }
}

然后在module中build.gradle引用插件plugin

apply plugin: 'com.android.application'
apply plugin: 'com.jakewharton.butterknife'

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

02-07 01:32