首次使用熱修復,成功修改了App中的一個小bug,感覺還是很神奇的。心情也是超好,記錄一下作為一個iOS初級開發者在開發中的成長。
望所有的程序員此生不枉那些熬夜加班通宵擼碼的艱辛,2017萬事大吉。
濕的BB一堆是時候來點干的:
什么是熱修復,什么是JSPatch?
熱修復:
iOS App可以在運行時從服務器拉取最新的js文件到本地執行,又因為js是一門動態的腳本語言,所以可以在運行時直接讀取js文件執行,也因此能夠實現ios的熱更新
或者說能夠使用JavaScript調用Objective-C的原生接口,從而動態植入代碼來替換舊代碼,實現修復線上bug等。
JSPatch:
JSPatch 是一個開源項目 ,只需要在項目里引入極小的引擎文件,就可以使用 JavaScript 調用任何 Objective-C 的原生接口,替換任意 Objective-C 原生方法
使用:
JSPatch第一步:
JSPatch先到平臺注冊賬號創建應用跟一般SDK一個套路的 下邊截圖:
1.創建應用(JSPatch平臺叫創建App,這里是需要AppStore的AppID的)
2.創建完App之后還是老套路得到一個appKey,用來接入JSPatch的引擎。
3.在程序中接入JSPatch引擎:完全按文檔來:我這里使用的cocoapods:podfile中添加:pod 'JSPatchPlatform' 返回直接pod install
4,接入完成就去AppDelegate 的didFinishLaunchingWithOptions調用appKey創建鏈接
// 一般寫入這些代碼就可以了如果下發腳本之前還需要調用其他代碼,詳情看文檔或者下方截圖我的處理
#import <JSPatchPlatform/JSPatch.h>
@implementation AppDelegate
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
[JSPatch startWithAppKey:@"你的AppKey"];
[JSPatch sync];
...
}
@end
下面介紹幾個個人認為常用的方法:
- +testScriptInBundle 見名知意,此方法用于發布前測試腳本
調用后,會在當前項目的bundle里尋找main.js(使用熱修復需要上傳js腳本文件,就是main.js格式,JSPatch引擎會拉取到腳本文件存儲到沙盒被動態調用)文件執行.不過此方法只是測試用,此時完成后要刪除掉.(我自己的見解,如果不對敬請諒解)
2.JSPatch 執行過程中的事件回調,在以下事件發生時會調用傳入的 block: +setupCallback:
typedef NS_ENUM(NSInteger, JPCallbackType){
JPCallbackTypeUnknow = 0,
JPCallbackTypeRunScript = 1, //執行腳本
JPCallbackTypeUpdate = 2, //腳本有更新
JPCallbackTypeUpdateDone = 3, //已拉取新腳本
JPCallbackTypeCondition = 4, //條件下發
JPCallbackTypeGray = 5, //灰度下發
};
// 調用:
[JSPatch setupCallback:^(JPCallbackType type, NSDictionary *data, NSError *error) {
switch (type) {
case JPCallbackTypeUpdate: {
NSLog(@"updated %@ %@", data, error);
break;
}
case JPCallbackTypeRunScript: {
NSLog(@"run script %@ %@", data, error);
break;
}
default:
break;
}
}];
3.定義用戶屬性用于條件下發腳本+setupUserData:
// 用于條件下發(在+sync之前調用)
[JSPatch setupUserData:@{
@"userid":@"156127",
@"location":@"ShiJiaZhuangStation"
}]
// 在后臺使用條件下發的時候使用:
例如:userId==156127, location=ShiJiaZhuangStation 逗號分隔
條件下發截圖:
4.加密用于下發腳本安全: +setupRSAPublicKey:
看見名字也很明了了加密用的方法(官方解釋:好處是,即使JSPatch被黑,黑客也不能通過腳本向你的app下發腳本,因為一但設置了只有你一個本地私鑰才可以下發成功,即使下發成功,沒有你本地的私鑰文件也不會通過執行)
解釋一下在JSPatch后臺下發腳本文件的時候會用到一個RSA的key 可以用JSPatch的也可以用自定義的,同樣需要在+sync之前調用,sync的時候大概已經成功拉取了腳本文件了
自己生成RSA的方法:
在終端輸入 openssl ,再執行以下三句命令,生成 PKCS8 格式的 RSA 公私鑰,執行過程中提示輸入密碼,密碼為空(直接回車)就行
genrsa -out rsa_private_key.pem 1024
pkcs8 -topk8 -inform PEM -in rsa_private_key.pem -outform PEM –nocrypt
rsa -in rsa_private_key.pem -pubout -out rsa_public_key.pem
這樣就會在當前目錄下生成兩個文件 rsa_private_key.pem 和 rsa_public_key.pem 之后就在程序設置rsa_public_key
[JSPatch setupRSAPublicKey:@"rsa_public_key.pem打開后的字符串,換行的地方需要手動加 '\n' ";
再從JSPatch下發腳本補丁的時候勾選使用自定義RSA key就會出現上傳框,選擇本地就可以了。
5.最后一個有助于調試的方法: +showDebugView
調用后會在stausBar出現一個小按鈕,點擊出現所有相關的log,方便調試(很好玩)
都是根據官方文檔寫的加深一下印象如有錯誤請多包涵并提醒,也希望能幫助碰巧遇到的小伙伴,更多關于JSPatch方法理解可以直接到官方直接看文檔,
關于寫js腳本的語法文檔
另外:JSPatch工具里邊有OC直接轉js的工具,自己看看文檔寫也是不錯的