思路
我开始想的是不管是视频还是其他文件加密应该是对数据流
的加密,我想到使用NSStream
在实际的操作的时候发现效率太低了 一个 100MB+文件 解密加密耗时太久了,于是打算用C来操作
加密->判断是否加密->文件头加密->内容加密
解密->判断文件头->对内容解密
代码:假定文件前9位做头加密
第一步打开文件 fopen()
FILE *fin = fopen([fpold cStringUsingEncoding:NSUTF8StringEncoding], "r");
FILE *fout = fopen([fpnew cStringUsingEncoding:NSUTF8StringEncoding], "wb+");
//保证文件有效
if (fin == NULL || fout == NULL) {
printf("fin == NULL || fout == NULL \n");
return @"";
}
其中文件使用方式是很讲究其中有几个特别要注意:
r 打开只读文件,该文件必须存在。
w 打开只写文件,若文件存在则文件长度清为0,即该文件内容会消失。若文件不存在则建立该文件。
b 读写打开一个二进制文件,允许读或在文件末追加数据。
第二步读取文件-判断是否加密
这是我开始写的
FILE *readFile;
readFile = fopen([path cStringUsingEncoding:NSUTF8StringEncoding], "rb+");
if (readFile != NULL) {
fseek(readFile, 0, SEEK_SET);
char list[9] = { 0 };
fread(list, sizeof(char), 9, readFile);
fclose(readFile);
readFile = NULL;
char wlist[9] = HEAD_KEY;
return strcmp(list, wlist);
}else{
printf("readFile == NULL\n");
}
看上去好像没什么问题但是好像发现有问题就是 strcmp
这个方法具体导致他们不同的原因是 list 和 wlist 赋值导致的,可以发现一个问题就是 wlist 里char[]是和 list 里char[]一样的
不难发现mmp 你们char都一样但是他们的char[]不一样 好绝望呀,不要紧我们把char取出来再比对(具体原因还请大佬告知一下)
NSMutableString *hexString = [NSMutableString string];
for (int i=0; i<sizeof(list); i++){
[hexString appendFormat:@"%02x ", list[i]];
}
NSMutableString *keyString = [NSMutableString string];
for (int i=0; i<sizeof(wlist); i++){
[keyString appendFormat:@"%02x ", wlist[i]];
}
return [keyString isEqualToString:hexString]?NO:YES;
第三步文件头加密
我干啥你只有两行代码你自己都不信
char wlist[10] = HEAD_KEY;
fputs(wlist,fout);
让我看看他们做什么了:
//获取到加密key
char wlist[10] = HEAD_KEY;
//写入文件(原因:w 打开只写文件,若文件存在则文件长度清为0,即该文件内容会消失。若文件不存在则建立该文件)
fputs(wlist,fout);
我们还差两步就完成了是不是很简单呀
第四步文件加密
char buf[READ_BUFF];
unsigned long nread ;
while( (nread = fread(buf, sizeof(char), READ_BUFF, fin)) ){
ccode(buf, nread);
fwrite(buf,sizeof(char),nread,fout);
}
是的就没了我们瞅瞅发生了什么
//每次读取流(buff)的大小
char buf[READ_BUFF];
//读取到的buff大小 作为循环开关
unsigned long nread ;
//循环去读取文件每次读取一个buff去处理
while( (nread = fread(buf, sizeof(char), READ_BUFF, fin)) ){
//对buff进行加密具体可以查看Demo
ccode(buf, nread);
//把加密后的buff写入文件
fwrite(buf,sizeof(char),nread,fout);
}
第五步文件解密
fseek(fin, 9, SEEK_SET);
char buf[READ_BUFF];
unsigned long nread ;
while( (nread = fread(buf, sizeof(char), READ_BUFF, fin)) ){
cdecode(buf, nread);
fwrite(buf,sizeof(char),nread,fout);
}
[图片上传失败...(image-30fde5-1526525205888)]
是的核心的代码基本写完了其实加密和解密是一个思路只是要跳过文件加密头部分
fseek(fin, 9, SEEK_SET);
接着对文件进行解密就行了.