AndFix:阿里巴巴开源Android App线上问题修复工具
AndFix这个库为Android App提供了热修复的功能。它能够帮助Android开发人员在线修复App Bug。
Andfix是" And roid hot- fix "首字母缩写。
AndFix支持Android 2.3 至 6.0, arm 和 x86 架构, dalvik runtime 和 art runtime.
AndFix's patch is .apatch file.
Principle
The implementation principle of AndFix is method's body replace :
bug fix process:
Integration
How to get?
- directly add AndFix aar to your project as compile libraries.
-
maven dependency:
<dependency> <groupId>com.alipay.euler</groupId> <artifactId>andfix</artifactId> <version>0.3.0</version> <type>aar</type> </dependency>
or gradle dependency:
dependencies { compile 'com.alipay.euler:andfix:0.3.0@aar' }
How to use?
-
initialize PatchManager:
patchManager = new PatchManager(context); patchManager.init(appversion);//current version
-
load patch. load patch as early as possible, generally, at the initialization phase of your app (such as application.oncreate()):
patchManager.loadPatch();
-
add patch. when new patch file has be downloaded,the patch will become effective immediately by add.
patchManager.addPatch(path);//path of the patch file that be downloaded
ProGuard
To ensure that these classes can be found after running an obfuscation and static analysis tool like ProGuard add the configuration below to your ProGuard configuration file.
-
native method
com.euler.cloudfix.CloudFix
-
annotation
com.euler.cloudfix.annotation.MethodReplace
-keep class * extends java.lang.annotation.Annotation -keepclasseswithmembernames class * { native <methods>; }
Developer Tool
The patch make tool is apkpatch.
How to get?
Apkpatch can be foundhere
How to use?
- generate .apatch file:
usage: apkpatch -f <new> -t <old> -o <output> -k <keystore> -p <***> -a <alias> -e <***> -a,--alias <alias> alias. -e,--epassword <***> entry password. -f,--from <loc> new Apk file path. -k,--keystore <loc> keystore path. -n,--name <name> patch name. -o,--out <dir> output dir. -p,--kpassword <***> keystore password. -t,--to <loc> old Apk file path.
- merge .apatch files:
usage: apkpatch -m <apatch_path...> -k <keystore> -p <***> -a <alias> -e <***> -a,--alias <alias> alias. -e,--epassword <***> 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.
Running sample
- import samples/AndFixDemo to your IDE, set AndFixDemo depend on AndFix(library project or aar).
- build project, save the package as 1.apk, and then install on device/emulator.
- modify com.euler.test.A, references com.euler.test.Fix.
- build project, save the package as 2.apk.
- use apkpatch to make a patch.
- rename the patch file to out.apatch, and then copy it onto sdcard.
- run 1.apk,view logcat.
API Documentation
The libraries javadoc can be found here