项目背景
JSPatch官网提供了打包好的SDK和功能非常丰富后台管理,可以使热修复功能实现起来So Easy。
如何集成请跳转
但是呢?天有不测风云,人有痴傻呆捏,偏偏就有这么一个需求,要求自己开发补丁后台,作为iOS 客户端开发,只好自己去github上下载并集成jspatch。这篇简书记录如何做到这一切。(只涉及到ISO客户端部分)
JSPatch平台与JSPatch的关系
什么是 JSPatch?
JSPatch 是一个开源项目(Github链接),只需要在项目里引入极小的引擎文件,就可以使用 JavaScript 调用任何 Objective-C 的原生接口,替换任意 Objective-C 原生方法。目前主要用于下发 JS 脚本替换原生 Objective-C 代码,实时修复线上 bug。
什么是 JSPatch 平台?
JSPatch 需要使用者有一个后台可以下发和管理脚本,并且需要处理传输安全等部署工作,JSPatch 平台帮你做了这些事,提供了脚本后台托管,版本管理,保证传输安全等功能,让你无需搭建一个后台,无需关心部署操作,只需引入一个 SDK 即可立即使用 JSPatch。
JSPatch SDK 与 github 上开源代码的关系?
Github 开源的是 JSPatch 核心代码,使用完全免费自由,若打算自己搭建后台下发 JSPatch 脚本,可以直接使用 github 上的核心代码,与 JSPatch 平台上的 SDK 无关。JSPatch 平台的 SDK 在核心代码的基础上增加了向平台请求脚本/传输解密/版本管理等功能,只用于这个平台。
接入JSPatch
1.下载jspatch,并导入到工程
下载的jspatch.png只需要导入以下文件即可:
导入文件.png
2.添加依赖项
添加 libz.dylib 和 JavaScriptCore.framework 依赖。
依赖项.png
热修复Demo
其实热修复的核心代码只有一句:
[JPEngine evaluateScript:script]; //script就是js补丁代码
写一个js文件放在本地的demo
#AppDelegate.m
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
[JPEngine startEngine];
NSString *sourcePath = [[NSBundle mainBundle] pathForResource:@"demo.js" ofType:nil];
NSString *script = [NSString stringWithContentsOfFile:sourcePath encoding:NSUTF8StringEncoding error:nil];
[JPEngine evaluateScript:script];
return YES;
}
#demo.js
require('UIView,UIColor,UIAlertView')
defineClass('ViewController', { buttonClicked : function() {
console.log('123');
var av = UIAlertView.alloc().initWithTitle_message_delegate_cancelButtonTitle_otherButtonTitles('提示', '补丁', null, 'OK', null, null);
av.show();
} })
#ViewController.m
- (void)viewDidLoad {
[super viewDidLoad];
UIButton *button = [[UIButton alloc]initWithFrame:CGRectMake(0, 100, [UIScreen mainScreen].bounds.size.width, 40)];
[button setTitle:@"button" forState:UIControlStateNormal];
[button setTitleColor:[UIColor blackColor] forState:UIControlStateNormal];
[button addTarget:self action:@selector(buttonClicked) forControlEvents:UIControlEventTouchUpInside];
[self.view addSubview:button];
}
-(void)buttonClicked {
}
demo.png
重难点问题
1.访问服务端接口
客户端访问补丁接口,入参为平台信息(iOS/安卓)和当前app版本号,接口返回参数包括补丁版本号、补丁信息说明、补丁下载地址。客户端将补丁版本号和本地补丁对比,如果补丁版本号一致则不下载补丁,执行本地补丁。如果不一致则下载新补丁并执行。
入参 | 出参 |
---|---|
平台信息、app版本号 | 补丁版本号、补丁信息说明、补丁下载地址 |
2.安全问题:如何加密
3.补丁意外处理
如果补丁本身存在问题造成app闪退,这就是一个很尴尬的问题了。
比如:
- 补丁下载时发生意外,导致补丁下载不全。
- 补丁加密、解密过程中发生意外,导致补丁代码错误。
- 补丁代码本身就存在问题。
遇到以上问题,我们改如何避免由于执行补丁导致的app崩溃闪退?
核心代码:
项目下载:
github
参考
小众应用的JSPatch集成(自己服务器)
JSPatch 部署安全策略
IOS热更新-JSPatch实现原理+Patch现场恢复
iOS利用JSPatch实现热修复的前后台代码
网友评论