iOSiOS开发札记iOS技术

iOS 文件加密/视频加密

2018-05-17  本文已影响5人  小布走慢点

思路

我开始想的是不管是视频还是其他文件加密应该是对数据流的加密,我想到使用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 @"";
    }

其中文件使用方式是很讲究其中有几个特别要注意:

其他都是一些组合的操作了

第二步读取文件-判断是否加密

这是我开始写的

    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);

接着对文件进行解密就行了.

上一篇下一篇

猜你喜欢

热点阅读