关于Android热修复技术(AndFix—阿里)
发布日期:2021-10-04 02:53:20 浏览次数:3 分类:技术文章

本文共 1423 字,大约阅读时间需要 4 分钟。

AndFix

是阿里开源的一个热修复工具,使用它可以在线修复方法bug达到让程序能实时的避免bug提示。

AndFix可以最大的优点是实时性加载补丁包,限制的地方:经过测试对添加调用新的Class和添加新Args不起效,其他的还是能正常修复,不过如果涉及到要使用新类来进行bug修复,那估计也得发布新版本了吧,因此AndFix还是能很好的满足日常需求的。


如何使用?


1 github下载补丁管理包()

这个是开源的,所以下载下来可以看看源码多多益善。
2 在APP的application中初始补丁管理包

public PatchManager mPatchManager;  //单个补丁包private static final String APATCH_PATH = "/newnew.apatch";mPatchManager=new PatchManager(getApplicationContext());// 初始化patch版本  mPatchManager.init("1.0");  // 加载已经添加到PatchManager中的patch  mPatchManager.loadPatch();  String patchFileString = Environment.getExternalStorageDirectory()                .getAbsolutePath() + APATCH_PATH;  Log.i("result", "patchFileString="+patchFileString);  Log.i("result", "补丁文件是否存在:"+new File(patchFileString).exists());try {        mPatchManager.addPatch(patchFileString);} catch (IOException e) {            // TODO Auto-generated catch block        e.printStackTrace();}

3 使用apkpatch分差工具生成需要修复的补丁(感觉这里和增量升级使用的分差工具是一样的),使用命令:

Cmd –>定位到apkpatch.bat所在的文件夹

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:别名密码(这样一般和密钥密码一致)

4 客户端下载服务器的补丁包到sd卡中(这里可以把补丁包都放入同一文件夹)

注意:别忘记添加app的读取和写入SD卡的权限


以下内容可以忽略….


AndFix大致原理记录下(用github上的):

AndFix的原理就是方法的替换,把有bug的方法替换成补丁文件中的方法。

这里写图片描述

实现使用C,C++底层进行指针替换修复bug。

整体流程如下:

这里写图片描述
这里写图片描述

具体底层实现可以看jni代码!

转载地址:https://blog.csdn.net/leifengpeng/article/details/50915860 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!

上一篇:关于使用tesseract-ocr开发简单的图文识别(转)
下一篇:Android网页加载本地JS文件

发表评论

最新留言

初次前来,多多关照!
[***.217.46.12]2024年03月29日 19时35分36秒