ios加密后的数据保存本地,解密时为何失败

来源:互联网 发布:煤矿生产能力数据库 编辑:程序博客网 时间:2024/06/02 06:44
之前,做项目时,我是用的是tea加密,(不懂的同学可以去网上搜,开源的)加完密,生成的是C的字符串,需要转化为NSString,或NSData 格式才能保存本地,接着问题就出来了,我再从本地取出来时,需要把本地保存的NSString或NSData 转换为C的字符串,就是这一步出问题了,才导致后面的解密错误。因为,加密生成的C的字符串,转换为NSString或NSData  时 ,相当于遍历这个C的字符串,每个字符都转为字符串保存在string或data里,后面等于说多了\n。那我该怎么办呢,下面就是我的解决方法
   1,前面不变,使用什么加密,依旧是用什么,无论tea,或des,aes都可以,加密完后,使用GTMBase64(第三方库,具体的自己百度),将C字符串转一下码,我使用的是+(NSString *)stringByEncodingBytes:(const void *)bytes length:(NSUInteger)length;转换成了字符串保存在了本地的plist文件
2.解密时,从本地,读取plist文件,    NSArray *paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);

    NSString *documentsDirectory = [paths objectAtIndex:0];

NSString *path = [documentsDirectory stringByAppendingPathComponent:@"shoppingCar.plist"];

NSData *data = [NSdata datawithcontentFile:path];

char buffer[1024*500] = [data bytes];//得到C的字符串

使用+(NSData *)decodeBytes:(const void *)bytes length:(NSUInteger)leng,
NSData *dataq = [self decodeBytes:buffer length:sizeof(buffer)]得到NSdata型数据;
在使用tea 解密
下面是我写的Demo
https://github.com/UniqueTC/Tea
0 0