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

1AF7FDDC-1146-43E2-A680-1E539DE2F192.png

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
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
-----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];
运行就好,这样就好了,希望可以对各位有所帮助。