c# - AES 128 跨平台 Swift/C#

标签 c# swift aes rijndaelmanaged

我一直在尝试在 iOS 和 .NET 上进行加密和解密,但不太成功。我使用了 this question 但收到错误:

Specified initialisation vector (IV) does not match the block size for this algorithm.

这是我使用 CryptoSwift 进行 Swift 加密的代码:

let encrypt = try! "oauth_token".AES_encrypt("my key here (is 32 characters long)", iv: "1234567890123456")

func AES_encrypt(key: String, iv: String) throws -> String {
    let data = self.dataUsingEncoding(NSUTF8StringEncoding)
    let enc = try AES(key: key, iv: iv, blockMode:.CBC).encrypt(data!.arrayOfBytes(), padding: PKCS7())
    let encData = NSData(bytes: enc, length: Int(enc.count))
    let base64String: String = encData.base64EncodedStringWithOptions(NSDataBase64EncodingOptions(rawValue: 0));
    let result = String(base64String)
    return result
}



我的 .NET 解密代码:

public static byte[] AES_Decrypt(byte[] bytesToBeDecrypted, byte[] key, byte[] iv)
    {
        byte[] decryptedBytes = null;

        using (MemoryStream ms = new MemoryStream())
        {
            using (RijndaelManaged AES = new RijndaelManaged())
            {
                AES.KeySize = 256;
                AES.BlockSize = 128;

                AES.Key = key;
                AES.IV = iv;

                AES.Mode = CipherMode.CBC;

                using (var cs = new CryptoStream(ms, AES.CreateDecryptor(), CryptoStreamMode.Write))
                {
                    cs.Write(bytesToBeDecrypted, 0, bytesToBeDecrypted.Length);
                    cs.Close();
                }
                decryptedBytes = ms.ToArray();
            }
        }

        return decryptedBytes;
    }



byte[] encrypted_text = Convert.FromBase64String("secret token");
byte[] key = Convert.FromBase64String("32 character key");
byte[] iv = Convert.FromBase64String("0123456789012345");

string plaintext = Convert.ToBase64String(AES_Decrypt(encrypted_text, key, iv));

最佳答案

block 大小为 16 字节 (AES.blockSize)。您使用的是旧版本,或者您的 AES_encrypt() 有问题(AES_encrypt 不是 CryptoSwift 的一部分)。

自述文件中的简单示例:

let input: NSData // data to encrypt
let encrypted = try? input.encrypt(AES(key: "secret0key000000", iv:"0123456789012345"))

或者这个

// Encrypt string and get Base64 representation of result
let base64: String = try? "my secret string".encrypt(AES(key: "secret0key000000", iv: "0123456789012345"))

关于c# - AES 128 跨平台 Swift/C#,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35212647/

相关文章:

ios - 上传到 App Store,无法在代码设计对话框中单击 "Always Allow"

encryption - nodejs中的AES 256 GCM加密解密

c# - 在字符串中使用二进制数据时数据是 "lost"吗?

c# - "Malformed Packet: TNS"从Oracle数据库检索数据

swift - 使用 Swift 检测 MacBook 盖子的打开/关闭?

ios - 物理 iPad Pro 设备返回的语音合成语音是否与其模拟器不同?

java - 使用 AES 在 Java 和 Python 中加密/解密

javascript - aes.js 和 crypto.js 最佳使用

c# - 与等效的 Webjobs 相比,队列触发的 Azure Functions 的等待时间非常长

c# - 刷新 EF 设计器时出现异常