JAR 和 AAR 的生成、使用方法及场景概论

JAR 和 AAR 区别以及使用场景 ?

JAR(Jave Archive) 是一种与平台无关的文件格式,允许将许多文件组合成一个压缩文件。 只包含 class 文件和清单文件,不包含资源文件。打 JAR 包,项目里面的 res 文件不可用,如果想用图片文件,可将图片放进 assets 文件打进 jar 包,但注意 jar 文件夹里面的文件不能和调用项目里面的 assets 文件里面的文件重名。

aar 是 Android 库项目的二进制归档文件,包含所有资源,class 以及 res 资源文件。将 aar 解压,会包含 AndroidManifest.xml、classes.jar、res、R.txt。

如只是简单的类库可选择 jar,如是 UI 库,包含布局文件以及资源等文件选择 aar。

如何生成 JAR 或者 AAR ?

使用 Android Stuido 创建一个工程,新建 Module,选择 Android Library,比如名称命名为 mylibrary,编写相应代码,如下图所示点击 assemble,即可生成 classes.jar 和 mylibrary-debug.aar 和 mylibrary-release.aar。

JAR 和 AAR 的生成、使用方法及场景概论

assemble 生成 jar aar

  • aar 路径:build/output/aar
  • jar 路径:build/intermediates/aar_main_jar/

需要注意的是 jar 包路径在不同的 gradle 版本中,路径不一致,如下是常见的路径:

  • build/intermediates/intermediate-jars/release/classes.jar
  • build/intermediates/packaged-classes/release/classes.jar
  • build/intermediates/aar_main_jar/release/classes.jar

如何修改改变 xxx.aar 名称?

 libraryVariants.all { variant ->
     variant.outputs.all { output ->
     def fileName =  "mylibrary_${defaultConfig.versionName}.aar"
     outputFileName = fileName
     }
 }

在 mylibrary 模块中的 build.gradle 文件中,配置如上代码,修改了 aar 的命名规则。

如何修改 xxxx.jar 名称和路径?

 task makeJar(type: Copy) {
     //jar 包命名规则
     def fileName =  "mylibrary_${defaultConfig.versionName}.jar"
     //jar 包默认路径
     from('build/intermediates/aar_main_jar/release/')
     //jar 包拷贝路径
     into('build/libs/')
     //jar 包默认名称 classes.jar
     include('classes.jar')
     //jar 包重命名
     rename('classes.jar', fileName)
 }
makeJar.dependsOn(build)

JAR 和 AAR 的生成、使用方法及场景概论

选择 mylibrary->Tasks->other->makeJar,会将 jar 文件拷贝到 build/libs 路径下,并按照新规则重命名。

如何使用 JAR 或者 AAR ?

如果是本地引用,一般需要将 jar 或 aar 放入 libs 目录下,在 build.gradle 文件中配置目录:

 repositories {
     flatDir {
        dirs '../libs'
     }
 }

然后在 dependencies 中引用即可:

dependencies {
    api(name: 'mylibrary_1.0', ext: 'aar')
}

如果是在线引用,需要配置服务器地址:

maven { url 'https://maven.aliyun.com/repository/jcenter' }
maven { url 'https://maven.aliyun.com/repository/google' }

//私服地址
maven {
    url 'http://xxx/xxx/xxx/'
    credentials {
    username 'username'
    password 'userpwd'
}

然后在 dependencies 中引用即可:

dependencies {
    api 'com.xxx.xxx:mylibrary:1.0'
}
上一篇:SpringBoot整合其它框架-整合Junit


下一篇:机器学习 周志华 课后习题 7.3