Android Studio如何打jar包和使用
- 生成jar包方式
 - module方式生成jar方式
 - 第一类修改主app的方式
 - 第二类:通过新建module方式生成jar包
 - 如何使用jar包
 
- aar生成并使用
 - aar生成
 - aar使用
 
之前有篇文章介绍了so库的生成和使用,看这里,但是,如果我们想把我们写的so库,通过java接口的方式提供出去,一般我们是打成jar包或者aar的形式提供,这篇文章介绍下如何打成jar包的,我们提供给使用方的是jar包和so库;
生成jar包方式
总的来说,AS打包生成jar包可以分成两类:
第一类是将应用模块application转换成库模块library后生成jar包
 第二类是通过新建module库模块的方式生成jar包
module方式生成jar方式
今天我们主要讲解第二种方式;
第一类修改主app的方式
简单写下将应用模块application转换成库模块library后生成jar包步骤:
- build.gradle 将com.android.application改成com.android.library
 - 注释掉applicationId
 - AndroidManifest.xml中application配置的属性去掉
 - 去掉Activity入口
 
后边的步骤和自建个module基本一致;
第二类:通过新建module方式生成jar包
新建module,File->New->New Module…
 
 选择Android Library,
 修改名称等配置,finish;
这个时候就可以在module中写代码了;
- 编写build文件
 
如图所示,我们暴露了一个getStrFromNative()的测试方法,这个方法是从so中获取了一个字符串,方法名和包名一定要跟so生成的时候一致;这样调用方调用native方法的时候才不会报错;
 
 真正生成jar包的方法在build.gradle文件下修改;
    task makeJar(type: Copy) {
        //删除存在的
        delete 'build/libs/jarsdk.jar'
        //设置拷贝的文件
        // from('build/intermediates/bundles/release/')
        from('build/intermediates/aar_main_jar/release/')
        //打进jar包后的文件目录
        into('build/libs/')
        //将classes.jar放入build/libs/目录下
        //include ,exclude参数来设置过滤
        //(我们只关心classes.jar这个文件)
        include('classes.jar')
        //重命名
        rename ('classes.jar', 'jarsdk.jar')
    }
    makeJar.dependsOn(build)
 
将如上代码写到module模块下的build.gradle文件下的android闭包内;
 
 2. 生成jar
 添加完后就可以生成啦,这里也有两种方式:
(1)通过cmd命令行方式
 在AndroidStudio->Terminal中输入命令:
gradlew makeJar
 
(2)
 通过Android Studio右边的Gradle的makeJar task;
 
 在module下的other目录里寻找到makejar,双击执行;
 
 如图所示就是成功了;
 
 如上图所示,在build->libs目录下,jarsdk就是生成的jar包;
如何使用jar包
将jar包拷贝到要使用的工程中,app->libs目录下;
 在app->src->main目录下新建jniLibs,将so库拷贝过来,如图:
 
 如果生成so库请参见这篇:Android JNI编程并生成so库
build.gradle中,android闭包下添加
    sourceSets {
        main {
            jniLibs.srcDirs = ['src/main/jniLibs', 'libs']
        }
    }
 
dependencies闭包下添加
 implementation files('libs/jarsdk.jar')
 
或者
implementation fileTree(dir: 'libs', include: ['*.jar'])
 
然后代码里就可以使用我们暴露的getStrFromNative()方法了;
case R.id.btn_test:
                Toast.makeText(getApplicationContext(), NdkTools.getStrFromNative(), Toast.LENGTH_LONG).show();
                break;
 

 说明成功了;
aar生成并使用
aar生成
aar的生成比较简单,参考第二步创建的module,新创建一个module,然后编写自己需要的代码;
 还是编写暴露的代码,如第二步中的getStrFromNative()方法;
 引入需要的so库,新建jniLibs文件夹,把so库拷贝进来
 
 然后就可以makeproject
 
 然后就在build-outputs-aar文件下就可以看到生成的aar文件;
 
aar使用
在使用的工程中,把aar拷贝到libs目录下:
 
 并且在build.gradle文件中引入
implementation files('libs/tts-debug.aar')
 
同步一下,就可以使用了getStrFromNative()方法了;
总结一下:
 aar的生成和使用比较简单,也是google为了方便大家并推荐的方式;而且aar里面可以包含资源和so;
 jar包的方式稍微麻烦一点,并且如果是提供sdk的话还得提供两部分代码,一个jar包和一个so库;


















