【问题标题】:Decrypt AES128/CBC in Objective-C from PHP从 PHP 解密 Objective-C 中的 AES128/CBC
【发布时间】:2014-07-07 19:16:23
【问题描述】:

我是 xCode 和 Objective-C 的新手。我编写了一个 QR 扫描仪,现在我需要解密使用 AES128 CBC 加密的数据。我在 php 中使用这个 sn-p 加密明文:http://www.androidsnippets.com/encrypt-decrypt-between-android-and-php

你能帮我吗?对不起我的英语不好,我是德国人:D

【问题讨论】:

  • 永远不会信任来自 AndroidSnippets 的加密代码。他们发布了最可怕的不安全代码,由于大量 Android 开发人员一生都没有看到过加密,因此获得了无限量的关注和投票。这只是另一个例子。
  • 代码中没有重要数据,但不是每个人都必须第一眼看到它背后的内容。
  • 好,解密失败再和你聊。

标签: ios objective-c encryption aes


【解决方案1】:

使用 CommonCrypto,参见 CommonCryptoCCCryptor

这里有一个片段可以帮助您入门:

+ (NSData *)doCipher:(NSData *)dataIn
                  iv:(NSData *)iv
                 key:(NSData *)symmetricKey
             context:(CCOperation)encryptOrDecrypt
               error:(NSError **)error
{
    CCCryptorStatus ccStatus   = kCCSuccess;
    size_t          cryptBytes = 0;    // Number of bytes moved to buffer.
    NSMutableData  *dataOut    = [NSMutableData dataWithLength:dataIn.length + kCCBlockSizeAES128];

    ccStatus = CCCrypt( encryptOrDecrypt,
                       kCCAlgorithmAES128,
                       kCCOptionPKCS7Padding,
                       symmetricKey.bytes, 
                       kCCKeySizeAES128,
                       iv.bytes,
                       dataIn.bytes,
                       dataIn.length,
                       dataOut.mutableBytes,
                       dataOut.length,
                       &cryptBytes);

    if (ccStatus == kCCSuccess) {
        dataOut.length = cryptBytes;
    }
    else {
        if (error) {
            *error = [NSError errorWithDomain:@"kEncryptionError"
                                         code:ccStatus
                                     userInfo:nil];
        }
        dataOut = nil;
    }

    return dataOut;
}

另请参阅RNCryptor 了解完整实现。

【讨论】:

  • 感谢您的帮助,我该如何调用此方法? NSData *decrypted = [doCipher ....]; ?对不起,我是一个绝对的新手:/
  • 你必须包含安全框架,#import ,像 [ClassName doCipher ...]; 一样调用它,其中 ClassName 是声明它的类的名称。确实要考虑RNCryptor,它是一个编译实现,我提供的是一个 sn-p,供精通 Objective-C 和一般加密的人使用。
  • 谢谢,效果很好:) 我忘记将 qr 数据从十六进制字符串转换为 NSData...谢谢! :)
猜你喜欢
  • 2020-03-29
  • 2014-01-27
  • 1970-01-01
  • 2011-12-10
  • 2017-07-10
  • 1970-01-01
  • 2013-03-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多