iOS 文件加密/视频加密

思路

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

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

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 33,537评论 18 399
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 136,169评论 19 139
  • java使用枚举类型,所以不用scala但是没有枚举类型,如果项目中 需要 用到枚举或者类似枚举 。scala ...
    Helen_Cat阅读 6,535评论 0 0
  • 上周学校集体春游 在春游前的一次班会课上 作为班主任的我 就环境保护、安全、纪律等方面给孩子做了周详的教育工作 在...
    OneSony阅读 5,415评论 1 7

友情链接更多精彩内容