在Android应用开发过程中,不同IDE对工程的依赖方式不一样:
使用Eclipse开发时,项目之间的依赖关系是这样的:一个主工程(project)可以依赖多个libproject、so、jar包,对jar包和so的依赖是直接将jar和so放在工程的libs文件夹下(老版本的ADT需要手动配置Build Path),对libproject的依赖呈现在工程的“project.properties”文件中。
使用Android Studio开发时,除了可以依赖module(对应Eclipse中的libproject)、jar和so,还可以依赖aar(aar和jar包不同之处在于可以将so和资源文件一起打包),as的依赖关系全部(jar、so、aar、libproject)在build.gradle文件中的android标签中管理。
使用AS开发应用时,除了可以依赖本地的库之外,还可以依赖网上(公有maven服务器、私有maven服务器、jcenter等),如果是依赖本地的,必须要将依赖的module和主工程放在一个project里面,这就导致了每个project都需要配置这些依赖关系,如果是公司内多个工程依赖同一个公司内部的控件,控件有更新时,同步非常麻烦,但公司内部的控件不可能部署到公有maven服务器上,所以有必要搭建一个局域网内的maven服务器,方便管理公司内部的公共库。
搭建maven私服使用得比较多的是Nexus,Nexus是基于maven仓库管理的社区项目,主要的使用场景就是可以在局域网搭建一个maven私服,用来部署第三方公共构件或者作为远程仓库在该局域网的一个代理。
关于Nexus的介绍和配置很简单,具体可以查看这里:Android 项目部署之Nexus私服搭建和应用。
上传库到私服有两种方式,一种是库中配置,配置完成后执行upload这个task,另外一种方式是直接上传。下面分别对这两种方式做介绍:
在库中配置,步骤如下:
1. 在project下的gradle.properties文件中定义通用属性,方便如果有多个库需要部署时,不需要修改每一个库中的配置:
#本地库
URLMAVEN_URL= http://172.28.1.*:8081/nexus/content/repositories/thirdparty/
MAVEN_SNAPSHOT_URL = http://172.28.1.*:8081/nexus/content/repositories/thirdparty-snapshot/
#对应maven的groupId值
GROUP=common
#登录nexus oss的用户名
NEXUS_USERNAME=admin
#登录nexus oss的密码
NEXUS_PASSWORD=admin123
# groupid
GROUP_ID = common
# type
TYPE = aar
# description
DESCRIPTION = dependences lib
2. 修改module对应的build.gradle文件,配置以谁的名义上传这个库,上传到什么地方,这个库叫什么名字,属于哪个group,ID和version、description、packageing等信息
apply plugin: 'com.android.library'
apply plugin: 'maven'
android {
compileSdkVersion 17
buildToolsVersion "23.0.2"
defaultConfig {
minSdkVersion 15
targetSdkVersion 17
versionCode 1
versionName "1.0"
}
buildTypes {
release {
minifyEnabled false
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
}
}
sourceSets {
main {
jniLibs.srcDirs = ['libs']
}
}
lintOptions {
abortOnError false
}
}
dependencies {
compile fileTree(dir: 'libs', include: ['*.jar'])
}
uploadArchives {
configuration = configurations.archives
repositories {
mavenDeployer {
snapshotRepository(url: MAVEN_SNAPSHOT_URL) {
authentication(userName: NEXUS_USERNAME, password: NEXUS_PASSWORD)
}
repository(url: MAVEN_URL) {
authentication(userName: NEXUS_USERNAME, password: NEXUS_PASSWORD)
}
pom.project {
version '1.0.0'
artifactId 'TestLibrary'
groupId GROUP_ID
packaging TYPE
description DESCRIPTION
}
}
}
}
artifacts {
archives file('TestLibrary.aar') }
3. 打开Gradle projects(在AS的右边栏),找到对应的module,展开,找到Tasks下面的upload标签并双击,在Gradle Console标签可以查看是否上传成功。
直接上传:直接上传很简单,直接按照下图的箭头操作即可,如果上传aar还没有研究过,有兴趣的可以自己研究一下:
在项目中使用私有仓库的步骤如下:
1. 在project的build.gradle文件中指定私有仓库的地址,like this:
2. 在需要依赖私有仓库的build.gradle文件中设置依赖关系: