最近公司要准备做热更新,没事的时候就尝试着研究了一下。然后看了一下JSPatch这个平台,发现很不错。有一个月的免费试用,并且给我们技工后台服务,这样就可以将js文件提交给她们,至少不用可怜兮兮的去央求着后台给你写个接口了。估计是自己挖掘能力不行,昨天弄了一天,今天想把过程记录下来,一方面是是给自己加深一下印象,一方面和大家分享一下。
言归正传,我们向JSPatch平台提供文件的方式分为两种,一种是rsa加密, 一种是不加密。
首先我们需要下载该平台的sdkhttp://www.jspatch.com/Index/sdk,
将它导入到项目当中,并且在Link Binary With Libraries 中进行配置
现在我们需要在平台上注册帐号,创建应用,生成appkey。
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如图
当上面打印出“ JSPatch: succ stat sent
”基本上就差不多了,这个时候可以查看本地Library里面
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
最终我们会在终端看到如下显示
并在指定的文件夹里面看到
-----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];
运行就好,这样就好了,希望可以对各位有所帮助。