ios - 从 PHP 解密 Objective-C 中的 AES128/CBC

标签 ios objective-c encryption aes

我是 xCode 和 Objective-C 的新手。我已经编码了 QR 扫描仪,现在我需要解密使用 AES128 CBC 加密的数据。我在 php 中使用以下代码片段加密明文: http://www.androidsnippets.com/encrypt-decrypt-between-android-and-php

你能帮我一下吗?抱歉我的英语不好,我是德国人:D

最佳答案

使用 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以便全面实现。

关于ios - 从 PHP 解密 Objective-C 中的 AES128/CBC,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23744348/

相关文章:

ios - 选择单元格时 UITableView 分隔符颜色发生变化

ios - 配置非续订订阅的持续时间

ios - 从子类添加 UIImageView 到 UIView

ios - iOS CLLocationManager 类和常量的错误

ios - 可重复使用的表格 View 单元格中的 UIButton 图像切换问题

IOS - 如何以编程方式阻止从另一个应用程序打开一个应用程序?

iphone - 检测哪个图像在 ScrollView 上

c++ - 在运行时暴力破解已知随 secret 钥的算法

java - 在 32 位系统上进行密码散列,然后迁移到 64 位系统

java - 使用 Hibernate 在 Java 中进行 SQLite 加密