美文网首页
JSPatch集成(自己服务器)

JSPatch集成(自己服务器)

作者: 还有梦想吗zZ | 来源:发表于2016-10-12 21:32 被阅读1061次

    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集成(自己服务器)

          本文链接:https://www.haomeiwen.com/subject/gjjiyttx.html