以前对于iOS来说,线上出现bug,都很苦恼,因为iOS上线审核周期太长,至少需要一周时间,还是在审核成功的情况下。很多公司都没有专业的测试员,都是程序员做测试,给程序员很大压力。如果出现bug,不能及时修复,所以很苦恼。我无意在查资料时,看到一篇文章,利用JSPatchPlatform框架可以线上修复bug,当时好激动啊。我们的福利啊。下面是JSPatchPlatform框架的介绍
> **作用**:是iOSApp获取脚本语言能力:动态更新App,替换项目原生代码修复bug。 当时听到JSPatch有这个动态修复bug的功能,感觉有点不可思议,同时觉得这个JSPatch简直太厉害了。用了它就可以及时修改App出现的bug,节约了上线先版本修复bug的时间。
>
> **根本原理**:利用OC的动态语言特性去动态修改类的方法实现,利用了OC的消息转发机制.
>
> **使用**:[JSPatch Platform](http://jspatch.com)就是一个第三方的JSPatch平台,帮助客户端开发者下发和管理脚本,处理传输安全等部署工作。 有了JSPatch平台就不用我们自己的后台去操作了,当然如果我们自己的后台愿意做能做也可以交给我们自己的后台去做。
* 首先需要登录官网注册(http://jspatch.com,成为它的一个用户
* 添加自己要使用JSPatch的App,添加App完成后会相应地有一个AppKey作为App的唯一标识
* App添加完成后我们还需要为App添加App版本,这样这个平台才能知道我们的哪个版
* 需要修复的代码的时候需要写一个js脚本本的App需要使用JSPatch进行代码动态修复
* 在 AppDelegate.m 里载入文件,并调用 +startWithAppKey: 方法,参数为第一步获得的 AppKey。接着调用 +sync 方法检查更新
#import
@implementation AppDelegate
1- (BOOL)application:(UIApplication*)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
[JSPatch startWithAppKey:@"你的AppKey"];
[JSPatch sync];
}
@end
* 假设已接入 JSPatch SDK 的某线上 APP 发现一处代码有 bug 导致 crash
@implementation XRTableViewController
. - (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath
{
NSString *content = self.dataSource[[indexPath row]]; //可能会超出数组范围导致crash
XRViewController *controller = [[JPViewController alloc] initWithContent:content];
[self.navigationController pushViewController:controller];
}
@end
* 对此我们写了如下 JS 脚本准备替换上述方法修复这个 bug
//main.js
defineClass("XRTableViewController", {
tableView_didSelectRowAtIndexPath: function(tableView, indexPath) {
var row = indexPath.row()
if (self.dataSource().length > row) { //加上判断越界的逻辑
var content = self.dataArr()[row];
var controller = XRViewController.alloc().initWithContent(content);
self.navigationController().pushViewController(controller);
}
}
})
如果我们不会写JS的话,平台还为我们提供脚本编辑器[http://www.jspatch.com/Tools/convertor](http://www.jspatch.com/Tools/convertor)可以进行编辑
这时我们需要在Xcode中创建一个main.js文件,创建一个空文件即可,JS脚本的文件名必须是**main.js**.
> 若使用 XCode8 接入,需要在项目 Capabilities 打开 Keychain Sharing 开关,否则在模拟器下载脚本后会出现 decompress error, md5 didn't match 错误(真机无论是否打开都没问题)
![Alt text](http://www.jspatch.com/Public/md/imgs/keychain.png)
> 若后续需要对这个脚本进行修改,可以重新上传新的脚本,APP 客户端会在请求时发现脚本已更新,下载最新脚本覆盖原来的,下次启动时执行。
> 若想直接取消某个 APP 版本的 JS 脚本补丁,可以直接在 APP 版本界面删除此 APP 版本,APP 客户端会在请求时发现脚本已被删除,即刻删除本地 JS 脚本文件,下次启动时不再加载。
这门技术的确挺叼的,腾讯、阿里都在用,我已经用到项目中了,感觉确实挺神奇。不错,我喜欢。