JSPatch集成(自己服务器)

0.前言

线上出了重大bug怎么办?代码错误导致不能注册账号,MACD线不显示,充值界面打不开?整个人都慌得不行,领导要骂了,更重要的是要扣工资了!! 怎么办!!有了JSPatch你再也不用重新发版本了。

【对JPLoader和JPCleaner的封装以及修复bug的示例Demo】

1.JSPatch简介

  • 它能够使用JavaScript调用Objective-C的原生接口,从而动态植入代码来替换旧代码,以实现修复线上bug。
    JSPatch传送门
原理
  • 我的理解就是利用JavaScript通过JavaScriptCore与Objective-C通信,再根据runtime达到我们想要目的。
    JSPatch详细原理传送门

2.背景

  • 在连续几个版本线上重大bug之后,真的被扣工资了(重点)
  • 最开始我是准备使用JSPatch平台的,不过经过调研后,发现通过用作者提供的源码,自己非常容易就可以搭建一个自己的脚本下发平台。安全策略传送门

3. 最初的想法

jspatch.png

4.最终的实现

完全利用作者的JPLoaderJPCleaner

  • packer.php脚本的使用 $ php packer.php main.js -o v2
    1.在本地打包和加密脚本文件

  • JPLoader做的事情:
    1.根据版本号向服务端拉取上述打包后的文件
    2.对文件进行 RSA 校验/解压/执行
    3.执行本地已下载的脚本

  • JPCleaner做的事情
    1.JSPatch 脚本执行后撤回脚本

  • manager的逻辑:
    1.进入程序 [JPLoader run];运行本地补丁文件。
    2.补丁抛出异常[JPCleaner cleanAll];清除本地补丁。
    3.每次启动都去自己服务器请求 返回格式 {"脚本version":"1" "downloadURL":"https://xxxxxxxx"}
    4.判断返回补丁号与正在使用补丁版本号,是否跟新。
    5.清除执行过的脚本,执行刚下载的脚本。

由于JPLoader是利用RSA加密,所以看这里RSA生成方法, 需要替换JPLoader.h的公钥和packer.php的私钥
提示:JSPatch Loader 只处理脚本校验,防止传输过程被第三方篡改,但不会对脚本内容进行加密传输和存储,对脚本内容有加密需求的可以自行加上加密逻辑

最终简单的集成了JSPatch以备不时之需。若对这东西要求很高,建议使用官方平台,或者自己设计一套适合自己业务的逻辑。:)

5.写脚本文件

建议利用【JSPatchConvertor】转换代码 ——> 再根据【JSPatch 基础用法】逐一修改 ——> 再加Safari调试技巧 ——> 本地充分的测试。确保每个发出的脚本都是修bug,而不是就是一个bug。

----最后,希望永远用不到JSPatch下发脚本。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • JSPatch是什么 JSPatch是一个开源项目,只需要在项目里引入极小的引擎文件,就可以使用 JavaScri...
    ImmortalSummer阅读 2,559评论 7 11
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 173,180评论 25 708
  • JSPatch作为热更新技术的黑科技,已经不是什么前沿的新闻了,像腾讯、美团等大公司也在使用JSPatch。前段时...
    任尔东西南北疯阅读 1,539评论 0 3
  • C++输出格式控制 在输出数据时,为简便起见,往往不指定输出的格式,由系统根据数据的类型采取默认的格式,但有时希望...
    MinoyJet阅读 2,373评论 0 0
  • 中国人好面子,远近闻名。因为好面子而放弃很多可能犯错的机会,也就错过许多成长的时机。真正权衡一下,好面子对于一个...
    我心永恒888阅读 455评论 0 0