熱修復(fù)臼节,即在沒有更新apk的情況下撬陵,對一些bug打補丁,原理簡單粗暴网缝,就是替換巨税,載入相關(guān)class之前把原來有bug的類替換掉,具體的實現(xiàn)過程比較抽象粉臊,這里不多加討論垢夹。主要說說怎么快速上手。
之前有一篇文章說到了自動檢測更新维费,覺得應(yīng)該弄篇熱修復(fù)和增量更新來配個套果元,于是研究了一下主流的熱修復(fù)框架,挑選了適合上手的一個方案:RocooFix
注1:本文實踐于 RocooFix熱修復(fù)框架方案
注2:本文demo參考derocoodemo,里面的key也借用了犀盟。
注3:本文demo與以上參考demo大同小異而晒,可對照食用。
開始霸某搿倡怎!
上代碼! HotFixDemo
相關(guān)配置
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'
}
}
配置簽名贱枣,因為一般都是在發(fā)布情況下才需要熱修復(fù)嘛监署,所以以下操作全都是針對于release版本操作。另外纽哥,注意看下面的注釋部分
signingConfigs {
test {
keyAlias 'shoyu'
keyPassword 'admin22'
storeFile file('doc/test.jks')
storePassword 'admin22'
}
}
defaultConfig {
...
minSdkVersion 15 //這里最低版本支持到API 15
...
versionCode 1 //這個值涉及到補丁版本發(fā)布
...
}
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 兩個文件復(fù)制到自己的libs下,編譯春塌。
2.doc文件夾下:jks簽名文件晓避,這個自己配置都行,隨便放哪只壳,上面storeFile路徑對就行俏拱。
3.在main/assets文件夾下:patch.jar、rocoo.dex吼句,示例锅必。MyApplicaton中有注釋說明。
4.最后是java代碼:主要是hotfix和util兩個包下面的內(nèi)容惕艳。注意導(dǎo)包搞隐。
5.MyApplicaton在manifest.xml中的
混淆配置
注意看自己的包名
好像就差不多了吧驹愚。
最終的編譯效果會在app路徑下生成rocoofix文件夾,如下圖:
使用
首先部署一個release版本到手機上
點擊右側(cè)gradle projects,選擇app/Tasks/install/installRelease,將會部署發(fā)布版到設(shè)備上尔许。如圖:
根據(jù)demo中的設(shè)定么鹤,運行點擊按鈕會是下圖的反應(yīng),嗯味廊,這是一個有bug的版本蒸甜,修復(fù)之前的狀態(tài)
然后去修復(fù)相關(guān)bug,此Demo里就是HelloHack類下的showHello方法的修改余佛,修改之后bug后柠新,修改module的build.gradle相關(guān)配置,主要就三個地方
1.versionCode 2版本號修改
2.rocoo_fix中辉巡,preVersionPath = '1' 取消注釋恨憎,開啟補丁制作
3.取消scanref = true注釋
編譯后app路徑下生成rocoofix下,如圖:
最后制作補丁包:點擊右側(cè)gradle projects,選擇app/Tasks/build/assembleRelease,如圖:
完事后會在rocoofix/version2/release/下生成patch.jar,如圖:
最后將patch.jar放置到圖3所示的目錄下郊楣,當(dāng)然這個目錄可以自己指定憔恳,最后部署后的運行效果:
注:須重啟應(yīng)用才能完成修復(fù)。
說點兒
熱修復(fù)聽起來不錯净蚤,但是也只能作為備用钥组,在產(chǎn)品上線后的無奈之舉,因為誰也不知道發(fā)布后會出現(xiàn)什么情況今瀑,熱修復(fù)就相當(dāng)于補考程梦,但是補考這種事,還是不要參與最好橘荠。另外屿附,熱修復(fù)肯定不適合大量的代碼修改,因為很難預(yù)料會出現(xiàn)什么狀況.
RocooFix框架解決了Nuwa因為Gradle1.40 里Transform API無法打包的情況哥童,現(xiàn)在兼容Gradle1.3-Gradle2.1.0版本挺份,基于QQ空間終端開發(fā)團隊的技術(shù)文章實現(xiàn),更多功能實現(xiàn)和局限性參看RocooFix
上代碼如蚜! HotFixDemo
【功能篇】擴展閱讀
《Android APP應(yīng)該有的東西》之功能篇:版本檢測更新
《Android APP可能有的東西》之功能篇:新功能高亮指引【薦】
本文作者:paradoxie
個人主頁:謝盒盒的小黑屋压恒,不止說技術(shù)
簡書地址:簡書主頁,專注技術(shù)類
github地址:paradoxie
轉(zhuǎn)載請注明出處错邦,蟹蟹!
-------我的夢想真的是做一條咸魚!