美文网首页
JSPatch热修复文件配置

JSPatch热修复文件配置

作者: 看个客人 | 来源:发表于2016-11-25 10:14 被阅读1070次

    最近公司要准备做热更新,没事的时候就尝试着研究了一下。然后看了一下JSPatch这个平台,发现很不错。有一个月的免费试用,并且给我们技工后台服务,这样就可以将js文件提交给她们,至少不用可怜兮兮的去央求着后台给你写个接口了。估计是自己挖掘能力不行,昨天弄了一天,今天想把过程记录下来,一方面是是给自己加深一下印象,一方面和大家分享一下。
    言归正传,我们向JSPatch平台提供文件的方式分为两种,一种是rsa加密, 一种是不加密。
    首先我们需要下载该平台的sdkhttp://www.jspatch.com/Index/sdk,
    将它导入到项目当中,并且在Link Binary With Libraries 中进行配置

    1AF7FDDC-1146-43E2-A680-1E539DE2F192.png ,然后我们将写好的js文件拖入到项目当中,调用[JSPatch testScriptInBundle]方法进行测试,要是加载正确,说明js文件无误,可以将它放到JSPatch平台上面去了。如果打印出来了“nw_proxy_resolver_create_parsed_array PAC evaluation error: NSPOSIXErrorDomain: 61”这个错误,其实也没什么影响,如果实在看着碍眼可以在Sheme中加入参数。
    1172550B-FC67-4A1F-AA0E-25CACCB389D0.png
    现在我们需要在平台上注册帐号,创建应用,生成appkey。
    0EE2FCF1-A3BB-4ACF-82E9-BCB15F090C5D.png
    1.我们先尝试一下不需要自定义rsa加密的。将main.js拖入进去,选择开发预览提交。在入口类里面写入方法,运行。
     [JSPatch startWithAppKey:@"appkey"];
      [JSPatch setupLogger:^(NSString * msg) {
            NSLog(@"error === %@",msg);
        }];
      [JSPatch setupDevelopment];//如果是选择“开发预览,这句代码很重要”
    [JSPatch sync];
    

    如果发现“decompress error, md5 didn't match, decrypt: md5:2fe9b05b8d4bcdbe7290e43706ef38d2
    ”这种错误,我们需要打开Keychain sharing如图


    00869238-79A5-47C5-819B-DEF71F19EFD0.png

    当上面打印出“ JSPatch: succ stat sent
    ”基本上就差不多了,这个时候可以查看本地Library里面


    8D4C4F6C-0CBB-440E-ADF2-C44DB4507414.png 这样无需加密上传js就配置好了,但是没有加密的js文件很容易被篡改,不是很安全,下面就来为大家介绍另一种rsa加密上传。我们可以通过终端执行openssl命令,生成公私两个文件。指定相应文件夹,在终端依次输入下面的代码,遇到要你输入密码的就直接回车
    openssl >
    genrsa -out rsa_private_key.pem 1024
    pkcs8 -topk8 -inform PEM -in rsa_private_key.pem -outform PEM –nocrypt
    rsa -in rsa_private_key.pem -pubout -out rsa_public_key.pem
    

    最终我们会在终端看到如下显示


    FA400D27-571A-475F-8C8E-2E7EC54BDA96.png

    并在指定的文件夹里面看到


    5B3DF601-6BD6-438A-81A8-207438B8B2F4.png 两个证书,rsa_private_key.pem我们用来和js文件一起上传到JSPatch服务器,rsa_public_key.pem我们用来获取公钥,获取的方式很简单,直接选择文本打开就好,这时候就能获取到一串公钥
    -----BEGIN PUBLIC KEY-----
    MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQC7yTgZjYxpX+mR6yfRADEUUoHw
    6AfIFeF+brXOf+XTDn7+oxzu02CB/58hIY4nzg6lEBPF4pdr/ZLkpBkL0PkTwkVJ
    p/OtG3CBxoyWmdCMYjXePAKnotJNs+tBnDW14OALgdXU3d+CnLBBpwGlpqqikePR
    EIlF8Y5wOSKFZSu5eQIDAQAB
    -----END PUBLIC KEY-----
    

    然后在加入相关方法

    [JSPatch startWithAppKey:@"appkey"];
    [JSPatch setupRSAPublicKey:@"MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQC7yTgZjYxpX+mR6yfRADEUUoHw6AfIFeF+brXOf+XTDn7+oxzu02CB/58hIY4nzg6lEBPF4pdr/ZLkpBkL0PkTwkVJ
    p/OtG3CBxoyWmdCMYjXePAKnotJNs+tBnDW14OALgdXU3d+CnLBBpwGlpqqikePREIlF8Y5wOSKFZSu5eQIDAQAB"];
      [JSPatch setupLogger:^(NSString * msg) {
            NSLog(@"error === %@",msg);
        }];
      [JSPatch setupDevelopment];//如果是选择“开发预览,这句代码很重要”
    [JSPatch sync];
    

    运行就好,这样就好了,希望可以对各位有所帮助。

    相关文章

      网友评论

          本文标题:JSPatch热修复文件配置

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