iOS AES解密遇到的问题

初始化向量(IV):AES的CBC加密模式,默认iv是16个0(这个称为初始化向量),由于是分组加密,所以下一组的iv,就用前一组的加密的密文来充当。CFB、OFB模式类似,只不过更复杂,加大破解难度

/

在解码出来得到字符串以后,我们会json字符串转换为NSData,但是有可能会有
Error Domain=NSCocoaErrorDomain Code=3840 "Garbage at end." UserInfo={NSDebugDescription=Garbage at end.}
这个错误,我跟一些大神找了好久,终于找出来了原因。因为我们获取的解密字符串会在末尾默认有一些转义字符(我们用NSLog打印时,并不能看到),我们需要把这些转义字符给去掉。不然会一直报那个错误

去掉解密出来字符串后面的一些转义字符

NSString * str2 = [str stringByReplacingOccurrencesOfString:@"\t" withString:@""];
    str2 = [str2 stringByReplacingOccurrencesOfString:@"\n" withString:@""];
    
    str2 = [str2 stringByReplacingOccurrencesOfString:@"\r" withString:@""];
    str2 = [str2 stringByReplacingOccurrencesOfString:@"\0" withString:@""];
    str2 = [str2 stringByReplacingOccurrencesOfString:@"\r\n" withString:@""];

如果你想要测试是不是我们得到的解密字符串真的有一些我们看不到的转义字符,我们可以进行字符串的截取

你会发现你减的数字已近超过了最后一位,我们的到的str2,应该是被剪切的jsonStr字符串,但是你打印一下,你会发现,这个字符串还是和jsonStr字符串字符串一样,这就是因为后面还有转义字符的原因

NSString * str2 = [str substringFromIndex:jsonStr.length - 3];

你还可以用这种方式进行测试,你会发现这个是可以的

    NSString *str2 = [[NSString alloc]init];
    for (int i = 0; i < str.length; i++) {
        unichar ch = [str characterAtIndex: i];
        NSString *str1 = [NSString stringWithFormat:@"%c",ch];
        str2 = [str2 stringByAppendingString:str1];
    }

你可能感兴趣的:(iOS AES解密遇到的问题)