JSPatch部署JS代码控制OC代码
前言:
这里算是比较实用的一篇了吧,进行了网络安全部署
准备:
bmob账号,JSPatch,公钥,私钥,MD5加密,AFNetWorking下载文件
#import <CommonCrypto/CommonDigest.h>
#import <BmobSDK/Bmob.h>
#import "AFNetworking.h"
#import "JPEngine.h"
#import "RSA.h"
原理:
1.使用bmob,得到私钥加密后的jsMD5,JS文件地址
2.根据地址下载js文件,并且保存到沙盒中
3.根据加密MD5匹配JS文件内容,成功就执行
4.没有进行网络判断,只有有网的情况才能执行,没网的时候就使用以前的OC代码
代码片段:
1.请求bmob上的数据
//这里是bmob的key自己去申请个账号,创建一个应用就有了
[Bmob registerWithAppKey:@"这里填写自己的key"];
BmobQuery *bquery = [BmobQuery queryWithClassName:@"JSPathString"];
//约束,只取版本号为1的
[bquery whereKey:@"version" equalTo:@""]; //是1得就取得
[bquery findObjectsInBackgroundWithBlock:^(NSArray *array, NSError *error) {
//删除操作,如果。。。。删除文件。。。。
if (!error) {
if (array.count > ) {
BmobObject *object = array[];
NSString *PrivateMD5String = [object objectForKey:@"PrivkeyMD5String"];
BmobFile *file = (BmobFile*)[object objectForKey:@"JSData"];
NSArray *path = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);
//取得第一个Documents文件夹的路径
NSString *filePath = [path objectAtIndex:];
// NSLog(@"%@",filePath);
[self downloadFileURL:file.url savePath:filePath fileName:file.name tag: PrivateMD5String:PrivateMD5String]; }
}else {
NSLog(@"失败的情况。。。");
}
}];
2.根据提供的地址下载文件
/**
* 下载文件,这是用的,网络请求,要换,现在都是af3.0了
*/
+ (void)downloadFileURL:(NSString *)aUrl savePath:(NSString *)aSavePath fileName:(NSString *)aFileName tag:(NSInteger)aTag PrivateMD5String:(NSString *)PrivateMD5String
{
NSFileManager *fileManager = [NSFileManager defaultManager]; //检查本地文件是否已存在
NSString *fileName = [NSString stringWithFormat:@"%@/%@", aSavePath, aFileName]; //检查附件是否存在
if ([fileManager fileExistsAtPath:fileName]) {
// NSLog(@"本地已经存在");
[self doJSPathWith:PrivateMD5String fileName:fileName]; }else{
//创建附件存储目录
if (![fileManager fileExistsAtPath:aSavePath]) {
[fileManager createDirectoryAtPath:aSavePath withIntermediateDirectories:YES attributes:nil error:nil];
} //下载附件
NSURL *url = [[NSURL alloc] initWithString:aUrl];
NSURLRequest *request = [NSURLRequest requestWithURL:url]; AFHTTPRequestOperation *operation = [[AFHTTPRequestOperation alloc] initWithRequest:request];
operation.inputStream = [NSInputStream inputStreamWithURL:url];
operation.outputStream = [NSOutputStream outputStreamToFileAtPath:fileName append:NO]; //下载进度控制 [operation setDownloadProgressBlock:^(NSUInteger bytesRead, long long totalBytesRead, long long totalBytesExpectedToRead) {
NSLog(@"is download:%f", (float)totalBytesRead/totalBytesExpectedToRead);
}]; //已经完成下载
[operation setCompletionBlockWithSuccess:^(AFHTTPRequestOperation * operation, id responseObject) {
//下载的数据
NSLog(@"下载成功");
[self doJSPathWith:PrivateMD5String fileName:fileName];
} failure:^(AFHTTPRequestOperation * operation, NSError * error) {
NSLog(@"下载失败");
}];
[operation start];
}
}
3.匹配检查JS文件是否正确
+ (void)doJSPathWith:(NSString *)PrivateMD5String fileName:(NSString *)fileName{
#pragma mark - 客户端操作,可以等待服务器,等待时间可以10's左右,网络请求后得到数据,然后还可以加一个开关按钮,可决定是否传这个js文件,以免出现BUG
//公钥
NSString *pubkey = @"MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQDCiw8lUn/RkpTFrIsC49i9ETR1\nRZuc265x7emOYgSLF4E2LkvxZk0klIC74MBDABhyN+TFQ2J9FkJX8XkzQkrnTv/G\nh0td+U+0D84tK81NJzBa1+pPXE55JjarwNLzf1VEfUBUWMoGKTVQV05sC0JjsYyX\nm6mbFq8j9v7ygO/FQQIDAQAB"; //服务器返回的RSA私钥加密的字符串字符串
NSString *fuwuqiMD5String = PrivateMD5String;
//服务器返回的JS字符串
NSString *script = [NSString stringWithContentsOfFile:fileName encoding:NSUTF8StringEncoding error:nil];; //公钥解密得到解密后的MD5字符串
NSString *decWithPrivKey = [RSA decryptString:fuwuqiMD5String publicKey:pubkey];
[JPEngine startEngine];
if ([[self md5:script] isEqualToString:decWithPrivKey]) {
// NSLog(@"匹配成功");
[JPEngine evaluateScript:script];
}else {
// NSLog(@"匹配失败");
}
}
4.其它(MD5加密)
//md5加密
+ (NSString *)md5:(NSString *)input {
const char* str = [input UTF8String];
unsigned char result[CC_MD5_DIGEST_LENGTH];
CC_MD5(str, (unsigned)strlen((const char *)str), result);
NSMutableString *ret = [NSMutableString string];
for(int i = ; i<; i++) {
[ret appendFormat:@"%02X",result[i]];
}
return ret;
}
JSPatch部署JS代码控制OC代码的更多相关文章
- JS代码和OC代码的相互调用
JS调用OC 很多应用里面或多或少的调用了网页,来达到绚丽的效果,所谓的JS调用OC.....举个例子吧,网页上有个按钮 点击按钮跳转界面,跳转的动作由OC的代码实现. OC调用JS 还是举个例子,我 ...
- JS游戏控制时间代码
var canvas = new HGAME.canvas();var testBox=document.getElementById('boxRender');testBox.appendChild ...
- iOS 使用UIWebView把oc代码和javascript相关联
首先请参看一篇文章,作者写的很明白,请参看原地址 http://blog.163.com/m_note/blog/static/208197045201293015844274/. 其实,oc和js的 ...
- iOS-JS调用OC代码
监听时间点击 改变当前浏览器窗口地址 在js里调用OC代码,需要在网页上写一个协议,不是http协议 然后在OC的webView shouldStartloadWithRequest
- ios-UIWebView中js和oc代码的互调
webview是ios中显示远程数据的网页控件,webview能显示的内容很多,MP4.文本.pdf等等: 关于js和oc代码的互相调用 1:oc中调用js代码; >>oc中调用js代码很 ...
- ios--网页js调用oc代码+传递参数+避免中文参数乱码的解决方案(实例)
此解决方案原理: 1.在ViewController.h中声明方法和成员变量,以及webView的委托: // // ViewController.h // JS_IOS_01 // // Cr ...
- js实现一套代码来控制所有的运动,图片的淡入淡出,winth,height的变宽
介绍了那么多运动,這次一套代码实现所有运动 1.html代码和css代码,只是定义一个div <style> div{ width:200px; height:200px; margin: ...
- JS弹出窗口代码大全(详细整理)
1.弹启一个全屏窗口 复制代码代码如下: <html> <body http://www.jb51.net','脚本之家','fullscreen');">; < ...
- js css样式操作代码(批量操作)
js css样式操作代码(批量操作) 作者: 字体:[增加 减小] 类型:转载 时间:2009-10-09 用js控制css样式,能让网页达到良好的的用户体验甚至是动画的效果.并且考虑到效率. ...
随机推荐
- css选择器(基础)
CSS选择器: 一个样式的语法是由选择器+属性+属性值三部分组成: 到底什么是选择器呢? 答:个人直白的理解为:选择一种要对它进行操作的标签的方法就叫做选择器.也就是说选择器就是一种选择元素的 ...
- DVWA之命令注入(command injection)
Command injection就是指通过提交恶意构造的参数破坏命令语句结构,从而达到执行恶意命令的目的 LOW 无论是Windows还是Linux,都可以使用&&连接多个命令 执行 ...
- 你不知道的HTTP之HTTPS
确保web安全的HTTPS HTTPS=HTTP+ 加密 + 认证 + 完整性保护 1.加密: 1)通信的加密 所谓互联网,是由能连通到全世界的网络组成的.无论世界哪个角 落的服务器在和客户端通信时, ...
- windows的cmd和git bash的常用命令
windows下使用git bash,使用的事linux下的命令,整理常用命令如下: windows下的命令 linux下的命令 命令的含义 cd e:\xx cd /e/xx 切换到xx目录 cd ...
- hadoop ssh 问题WARNING: REMOTE HOST IDENTIFICATION HAS CHANGED!
0.0.0.0: @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@0.0.0.0: @ WARNING: REMOTE HO ...
- 诊断 Grid Infrastructure 启动问题 (文档 ID 1623340.1)
适用于: Oracle Database - Enterprise Edition - 版本 11.2.0.1 和更高版本本文档所含信息适用于所有平台 用途 本文提供了诊断 11GR2 和 12C G ...
- flask--Django 基本使用
#导入flaskfrom flask import Flask #创建应用 app = Flask(__name__) #创建根路径视图 @app.route('/') def hello_world ...
- Gradle环境下导出Swagger为PDF
更多精彩博文,欢迎访问我的个人博客 说明 我个人是一直使用Swagger作为接口文档的说明的.但是由于在一些情况下,接口文档说明需要以文件的形式交付出去,如果再重新写一份文档难免有些麻烦.于是在网上看 ...
- 解决IllegalBlockSizeException:last block incomplete in decryption异常
解决IllegalBlockSizeException:last block incomplete in decryption异常分类: webkit android最近做个加解密的实现,虽然实现了, ...
- Encryption-基础:MD5加密
环境:vc2003 .h /* MD5.H - header file for MD5C.C */ /* Copyright (C) 1991-2, RSA Data Security, Inc. C ...