2014-02-19 50 views
0

我尝试使用CCCrypt的方法,但我得到的Xcode 3.2.6时,Xcode 4和Xcode的5个不同的结果;都有Mac OS X 10.6。 我用下面的代码来解密数据CCCrypt上的Xcode 4和Xcode的5不起作用(得到不同的结果)

- (NSData*)decryptData:(NSData*)data key:(NSData*)key iv:(NSData*)iv 
{ 
    NSData* result = nil; 

    // setup key 
    unsigned char cKey[kCCKeySizeAES256]; 
    bzero(cKey, sizeof(cKey)); 
    cKey[0] = 0; 
    [key getBytes:cKey length:kCCKeySizeAES256]; 

    // setup iv 
    char cIv[kCCBlockSizeAES128]; 
    bzero(cIv, kCCBlockSizeAES128); 
    if (iv) { 
     [iv getBytes:cIv length:kCCBlockSizeAES128]; 
    } 

    // setup output buffer 
    size_t bufferSize = [data length] + kCCBlockSizeAES128; 
    void *buffer = malloc(bufferSize); 

    // do decrypt 
    size_t decryptedSize = 0; 
    CCCryptorStatus cryptStatus = CCCrypt(kCCDecrypt, 
              kCCAlgorithmAES128, 
              kCCOptionPKCS7Padding, 
              cKey, 
              kCCKeySizeAES256, 
              cIv, 
              [data bytes], 
              [data length], 
              buffer, 
              bufferSize, 
              &decryptedSize); 

    if (cryptStatus == kCCSuccess) { 
     result = [NSData dataWithBytesNoCopy:buffer length:decryptedSize]; 
    } else { 
     free(buffer); 
     NSLog(@"[ERROR] failed to decrypt| CCCryptoStatus: %d", cryptStatus); 
    } 

    return result; 
} 

在Xcode中3.2.6我得到的实际结果,而在Xcode 5的结果是“”。

+1

确保你的操作系统上运行10.6 Xcode的5 ..? – Jay

+0

最好的选择:iv或者key或者两者都不正确,可能会缩短,所以一些随机数据正在进入。 NSLog记录它们并进行比较。此外,差异不是Xcode版本,而是使用的SDK。简而言之,CCCrypt的作品,重新认为你的代码。 – zaph

+0

Lion Lion上的Xcode5和Lion上的XCode4.3.3都有base sdk macosx10.6。我在这个不同的平台上执行相同的代码。 – sam

回答

0

最好的办法:无论是静脉或密钥或两者都是不正确的,可能要短,所以一些随机数据进入他们。 NSLog登录并比较

差异不Xcode的版本,但使用的SDK。总之,CCCrypt的作品,审查你的代码。

CBC模式需要IV,ECB模式没有。