美文网首页androidAndroid知识Android技术知识
《Android APP应该有的东西》之功能篇:热修复

《Android APP应该有的东西》之功能篇:热修复

作者: 温瑜 | 来源:发表于2016-10-20 17:33 被阅读616次

    热修复,即在没有更新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文件夹,如下图:

    1

    使用

    首先部署一个release版本到手机上

    点击右侧gradle projects,选择app/Tasks/install/installRelease,将会部署发布版到设备上。如图:

    2

    根据demo中的设定,运行点击按钮会是下图的反应,嗯,这是一个有bug的版本,修复之前的状态

    3

    然后去修复相关bug,此Demo里就是HelloHack类下的showHello方法的修改,修改之后bug后,修改module的build.gradle相关配置,主要就三个地方

    1.versionCode 2版本号修改
    2.rocoo_fix中,preVersionPath = '1' 取消注释,开启补丁制作
    3.取消scanref = true注释
    

    编译后app路径下生成rocoofix下,如图:

    4

    最后制作补丁包:点击右侧gradle projects,选择app/Tasks/build/assembleRelease,如图:

    5

    完事后会在rocoofix/version2/release/下生成patch.jar,如图:

    6

    最后将patch.jar放置到图3所示的目录下,当然这个目录可以自己指定,最后部署后的运行效果:

    7

    注:须重启应用才能完成修复。

    说点儿

    热修复听起来不错,但是也只能作为备用,在产品上线后的无奈之举,因为谁也不知道发布后会出现什么情况,热修复就相当于补考,但是补考这种事,还是不要参与最好。另外,热修复肯定不适合大量的代码修改,因为很难预料会出现什么状况.

    RocooFix框架解决了Nuwa因为Gradle1.40 里Transform API无法打包的情况,现在兼容Gradle1.3-Gradle2.1.0版本,基于QQ空间终端开发团队的技术文章实现,更多功能实现和局限性参看RocooFix

    上代码! HotFixDemo

    【功能篇】扩展阅读

    《Android APP应该有的东西》之功能篇:版本检测更新

    《Android APP可以有的东西》之功能篇:右滑返回

    《Android APP可能有的东西》之功能篇:新功能高亮指引【荐】


    本文作者:paradoxie
    个人主页:谢盒盒的小黑屋,不止说技术
    简书地址:简书主页,专注技术类
    github地址:paradoxie
    转载请注明出处,蟹蟹!
    -------我的梦想真的是做一条咸鱼!

    相关文章

      网友评论

      • 爱在蔓延中:微信tinker
      • wan7451:那个jar如何能跑到用户的手机上
        温瑜: @Androider_ 放到服务端,客户端检测下载,类似于版本升级,只是这个是暗中完成的,因为那个jar一般都很小,不会耗多少流量

      本文标题:《Android APP应该有的东西》之功能篇:热修复

      本文链接:https://www.haomeiwen.com/subject/nxafuttx.html