Android AndFix 热修复框架

今天带来的是阿里的热修复框架AndFix使用,废话不多说直接看下文。

项目Git地址:https://github.com/alibaba/AndFix

lib包:AndFixLib

补丁制作工具: apkpatch

ps:上面下载的包里面会发现.so文件和官方的不一样,这里要特殊说明下,由于在64位平台上使用时会报错,所以这里是通过Android studio添加依赖'com.alipay.euler:andfix:0.4.0@aar' 然后在C:\Users…gradle\cache.. 下面找到 andfix-0.4.0.aar,解压缩,从里面取出 .so文件,然后放在官方下载的Eclipse下的demo里面使用(这里很奇怪官方的demo为什么是eclipse的)。这个问题也是在issue里面有网友提供的。

下载来看看使用方式,如果想了解原理的可以上官网看看,这里就不说了。

使用

如果你用的是AS的话就直接添加依赖

``` dependencies {
 compile 'com.alipay.euler:andfix:0.4.0@aar'
}

然后.so包可以使用上面下载的。

如果是使用的Eclipse的就直接全部使用上面的那个lib包就好了。

接下来在继承Application的类里面添加初始方法:

一、

初始化
patchManager = new PatchManager(context);
patchManager.init(appversion);//current version
patchManager.loadPatch();

二、在需要加载补丁的地方调用

patchManager.addPatch(path);//path 是你补丁在本地存储的路径,一般修复线上项目得通过后台下载补丁到sd卡

三、生成补丁
知道使用方法了,接下来就是制作补丁了,下载上面提供的补丁制作工具apkpatch,然后解压到本地
通过命令行进入到该目录下,这里需要:有bug的apk包、修复后的apk包、密钥。(这里建议所有东西都放解压目录下比较方便)

apkpatch.bat –f new.apk –t old.apk –o output –k abc.keystore –p 111111 -a abc.keystore -e 111111

-f new.apk :指定新的版本apk -t old.apk :指定旧版本有bug的apk -o output :生成的补丁文件所放的文件夹 -k abc.keystore :打包密钥 -p 111111 :打包密钥密码 -a abc.keystore :打包别名密钥 -e 111111 :打包别名密钥密码(这样一般和密钥密码一致)

如果有多个补丁的话可以使用下面的命令进行补丁合并:

apkpatch -m <apatch_path...> -o <output> -k <keystore> -p <***> -a <alias> -e <***>
 -a,--alias <alias> keystore entry alias.  -e,--epassword <***> keystore entry password.  -k,--keystore <loc> keystore path.  -m,--merge <loc...> path of .apatch files.  -n,--name <name> patch name.  -o,--out <dir> output dir.  -p,--kpassword <***> keystore password.

最后会在指定目录下生成.apatch文件,将其放入sd卡中就可以测试啦。

好了以上就是基本的集成使用方式了,加上和之前使用的RocooFix框架做对比,发现AndFix覆盖面大一点(不过也有网友反映会报错),测试了三台手机RocooFix只有一台有效,AndFix三台都可以,不得不说阿里粑粑还是牛*的。总的来说现在的热修复框架还没达到很成熟的地步,以上两种只是能修改些类里面的方法,而不能添加类和其他文件,对于修复一些比较小的紧急bug还是可以的,但是覆盖面还有待考证。不过AndFix是基于jni来实现,在安全方面会更好些。

由于android热修复的缺陷,现在比较火热的还属React-Native、Weex。 有兴趣的同学可以去研究下。

以上是个人见解,如有不对还望指出。

你可能感兴趣的:(框架,android)