热修复,即在没有更新apk的情况下,对一些bug打补丁,原理简单粗暴,就是替换,载入相关class之前把原来有bug的类替换掉,具体的实现过程比较抽象,这里不多加讨论。主要说说怎么快速上手。
之前有一篇文章说到了自动检测更新,觉得应该弄篇热修复和增量更新来配个套,于是研究了一下主流的热修复框架,挑选了适合上手的一个方案:RocooFix
注1:本文实践于 RocooFix热修复框架方案
注2:本文demo参考derocoodemo,里面的key也借用了。
注3:本文demo与以上参考demo大同小异,可对照食用。
开始啊!
上代码! HotFixDemo
相关配置
1.项目的build.gradle:
dependencies {
classpath 'com.android.tools.build:gradle:2.1.2'
classpath 'com.dodola:rocoofix:1.2.6'//添加
}
2.module的build.gradle:
apply plugin: 'com.android.application'
apply plugin: 'com.dodola.rocoofix'//添加
repositories {
flatDir {
dirs 'libs'
}
}
配置签名,因为一般都是在发布情况下才需要热修复嘛,所以以下操作全都是针对于release版本操作。另外,注意看下面的注释部分
signingConfigs {
test {
keyAlias 'shoyu'
keyPassword 'admin22'
storeFile file('doc/test.jks')
storePassword 'admin22'
}
}
defaultConfig {
...
minSdkVersion 15 //这里最低版本支持到API 15
...
versionCode 1 //这个值涉及到补丁版本发布
...
}
buildTypes {
release {
minifyEnabled true // 注意:一定要开启混淆
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
signingConfig signingConfigs.test
}
}
dependencies {
...
compile 'com.dodola:rocoo:1.1'
compile(name: 'AndroidQuery-release', ext: 'aar')
}
rocoo_fix {
includePackage = ['cf/paradoxie/hotfixdemo']
excludeClass = ['MyApplicaton.class', 'HotFixManger.class', 'BasePermissionActivity.class']
// preVersionPath = '1'//制作补丁版本时开启
// scanref = true //制作补丁版本事开启
enable = true
}
文件配置
1.libs文件夹下:AndroidQuery-release.aar、commons-codec-1.10.jar 两个文件复制到自己的libs下,编译。
2.doc文件夹下:jks签名文件,这个自己配置都行,随便放哪,上面storeFile路径对就行。
3.在main/assets文件夹下:patch.jar、rocoo.dex,示例。MyApplicaton中有注释说明。
4.最后是java代码:主要是hotfix和util两个包下面的内容。注意导包。
5.MyApplicaton在manifest.xml中的
混淆配置
注意看自己的包名
好像就差不多了吧。
最终的编译效果会在app路径下生成rocoofix文件夹,如下图:
使用
首先部署一个release版本到手机上
点击右侧gradle projects,选择app/Tasks/install/installRelease,将会部署发布版到设备上。如图:
根据demo中的设定,运行点击按钮会是下图的反应,嗯,这是一个有bug的版本,修复之前的状态
然后去修复相关bug,此Demo里就是HelloHack类下的showHello方法的修改,修改之后bug后,修改module的build.gradle相关配置,主要就三个地方
1.versionCode 2版本号修改
2.rocoo_fix中,preVersionPath = '1' 取消注释,开启补丁制作
3.取消scanref = true注释
编译后app路径下生成rocoofix下,如图:
最后制作补丁包:点击右侧gradle projects,选择app/Tasks/build/assembleRelease,如图:
完事后会在rocoofix/version2/release/下生成patch.jar,如图:
最后将patch.jar放置到图3所示的目录下,当然这个目录可以自己指定,最后部署后的运行效果:
注:须重启应用才能完成修复。
说点儿
热修复听起来不错,但是也只能作为备用,在产品上线后的无奈之举,因为谁也不知道发布后会出现什么情况,热修复就相当于补考,但是补考这种事,还是不要参与最好。另外,热修复肯定不适合大量的代码修改,因为很难预料会出现什么状况.
RocooFix框架解决了Nuwa因为Gradle1.40 里Transform API无法打包的情况,现在兼容Gradle1.3-Gradle2.1.0版本,基于QQ空间终端开发团队的技术文章实现,更多功能实现和局限性参看RocooFix
上代码! HotFixDemo
【功能篇】扩展阅读
《Android APP应该有的东西》之功能篇:版本检测更新
《Android APP可能有的东西》之功能篇:新功能高亮指引【荐】
本文作者:paradoxie
个人主页:谢盒盒的小黑屋,不止说技术
简书地址:简书主页,专注技术类
github地址:paradoxie
转载请注明出处,蟹蟹!
-------我的梦想真的是做一条咸鱼!