一次编码问题调试经历

背景介绍

  • 将文件内容用AES128加密一下

  • 将文件放后台,并事先计算出文件内容的md5值

  • 客户端下载,先计算md5,保证文件没有被修改

  • AES128解密,获得原始内容,使用

原始方案

加密端

  • 读取文件,并转成NSData格式,UTF8编码

  • 对NSData用AES128加密

  • 计算md5值,存文件

解密端

  • 读取文件,并转成NSData格式,UTF8编码

  • 这是密文,计算md5值,检查文件是否被篡改

  • AES128解密,获取原始内容,转成NSString使用

问题

  • 将NSData直接存文件,隐含了将二进制当字符处理了。结果会发现解密出来的文件会大很多,md5,和内容都不对。

  • NSData可以理解为数据流,而涉及到文件操作,需要字符串,而base64有个方法就是将流和字符串进行转换。

解决方案

在存文件之前,将NSData转成base64字符串,再存,就不会出现这种问题了。当然解密过程要加一个base64解密。

例子代码

- (void)encodeProcess {
    NSString *path = [[NSBundle mainBundle] pathForResource:@"patch-raw" ofType:@"js"];
    NSLog(@"path: %@", path);
    NSString *rawString = [NSString stringWithContentsOfFile:path encoding:NSUTF8StringEncoding error:nil];
    NSLog(@"rawString: %@", rawString);
    NSData *rawData = [rawString dataUsingEncoding:NSUTF8StringEncoding];
    NSLog(@"rawData: %@", rawData);
    NSData *encryptData = [rawData AES128EncryptWithKey:encodeKey gIv:ivKey];
    NSLog(@"encryptData: %@", encryptData);
    NSString* base64String = [encryptData base64EncodedStringWithOptions:NSDataBase64Encoding64CharacterLineLength];
    NSLog(@"base64String: %@", base64String);
    NSString *md5 = [base64String MD5String];
    NSLog(@"md5: %@", md5);
}

- (void)decodeProcess {
    NSString *path = [[NSBundle mainBundle] pathForResource:@"patch" ofType:@"js"];
    NSLog(@"path: %@", path);
    NSString *base64String = [NSString stringWithContentsOfFile:path encoding:NSUTF8StringEncoding error:nil];
    NSLog(@"base64String: %@", base64String);
    NSString *md5 = [base64String MD5String];
    NSLog(@"md5: %@", md5);
    NSData *encryptData = [[NSData alloc] initWithBase64EncodedString:base64String options:NSDataBase64DecodingIgnoreUnknownCharacters];
    NSLog(@"encryptData: %@", encryptData);
    NSData *decodeData = [encryptData AES128DecryptWithKey:encodeKey gIv:ivKey];
    NSLog(@"decodeData: %@", decodeData);
    NSString *rawString = [[NSString alloc] initWithData:decodeData encoding:NSUTF8StringEncoding];
    NSLog(@"rawString: %@", rawString);
}

patch-raw.js

defineClass('PolicyCell',{loadData_policeType:function(data,type){self.ORIGloadData_policeType(data,type);self.lbGroup().removeFromSuperview();}}, {})

patch.js

823SE2VxM7H65r9synXs+IWwZA5CY8oFoG3YM5OPn6D+vr5ZWOvUTb7Rb63/HyHs
lNh1Ugd+ZK3kQTIrvDZfyHH+ht+CGcQYWCxYmlcp5M9slsvGEC+haiL4ttpjT/cd
Kx+eh2EUi9MgaBZsz7yC0yQhGXb6M7FFTA4lzba7uPi1M5qTXpLMYsLGqkxFN5EW
kUV7N4F9qQcXqSSyhloS8A==

md5

前后两段的md5是对不起来的,原因是将base64字符copy到文件时可能带上一些空格等不可见字符。不过对实际的功能没有影响。

data格式的base64

  • 如果要存文件,还是用上面的base64字符串比较好

  • data格式的base64在这里不是很好用,不建议用

AES128

  • key什么的不同,加解密之后的字符串就不同,只要能对起来就可以了。

  • 如果不涉及网络传输,就不需要md5,AES128之类的,调试都很麻烦

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • /**ios常见的几种加密方法: 普通的加密方法是讲密码进行加密后保存到用户偏好设置( [NSUserDefaul...
    彬至睢阳阅读 3,029评论 0 7
  • 首先罗列一些知识点: 1.加密算法通常分为对称性加密算法和非对称性加密算法:对于对称性加密算法,信息接收双方都需事...
    JonesCxy阅读 1,438评论 2 4
  • 1.数据安全 01 攻城利器:Charles(公司中一般都使用该工具来抓包,并做网络测试) 注意:Charles在...
    Lucky丶晴阅读 1,478评论 0 9
  • 1.备香虐(不要打我) 2小学生文笔不喜勿喷 上. 民国十年. 京城...
    Ada的小娇妻阅读 197评论 0 1
  • 北上广深是伟大的城市,里面有伟大的人,伟大的事,以及...伟大的机会,嗯。 我也渴望伟大,未来逆袭的机会,对于平民...
    Bottle丶Fish阅读 159评论 0 0