热修复

JSPatch自定义后台

2017-01-16  本文已影响42人  ImmortalSummer

项目背景

JSPatch官网提供了打包好的SDK和功能非常丰富后台管理,可以使热修复功能实现起来So Easy。
如何集成请跳转
但是呢?天有不测风云,人有痴傻呆捏,偏偏就有这么一个需求,要求自己开发补丁后台,作为iOS 客户端开发,只好自己去github上下载并集成jspatch。这篇简书记录如何做到这一切。(只涉及到ISO客户端部分)


JSPatch平台与JSPatch的关系

引文自:http://jspatch.com/Docs/intro

什么是 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,并导入到工程

去Github下载

下载的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版本号 补丁版本号、补丁信息说明、补丁下载地址
流程图.png

2.安全问题:如何加密

3.补丁意外处理

如果补丁本身存在问题造成app闪退,这就是一个很尴尬的问题了。
比如:

  1. 补丁下载时发生意外,导致补丁下载不全。
  2. 补丁加密、解密过程中发生意外,导致补丁代码错误。
  3. 补丁代码本身就存在问题。
    遇到以上问题,我们改如何避免由于执行补丁导致的app崩溃闪退?

核心代码:

项目下载:
github

参考

小众应用的JSPatch集成(自己服务器)
JSPatch 部署安全策略
IOS热更新-JSPatch实现原理+Patch现场恢复
iOS利用JSPatch实现热修复的前后台代码

上一篇下一篇

猜你喜欢

热点阅读