【发布时间】:2012-10-14 05:44:29
【问题描述】:
尝试在Android和iOS中使用带有CBC和PKCS7填充的AES128算法加密样本数据,但结果不同:(
安卓代码:
private static final byte[] KEY = { 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09, 0x0A, 0x0B, 0x0C, 0x0D, 0x0E, 0x0F, 0x10};
int srcBuffSiz = 1024;
byte[] srcBuff = new byte[srcBuffSiz];
Arrays.fill(srcBuff, (byte)0x01);
SecretKeySpec skeySpec = new SecretKeySpec(KEY, "AES");
Cipher ecipher = Cipher.getInstance("AES/CBC/PKCS7Padding");
ecipher.init(Cipher.ENCRYPT_MODE, skeySpec);
byte[] dstBuff = ecipher.doFinal(srcBuff);
int bytesEncrypted = dstBuff.length;
iOS 代码:
// Source buffer
size_t srcBuffSiz = 1024;
unsigned char* srcBuff = new unsigned char[srcBuffSiz];
memset(srcBuff, 0x01, srcBuffSiz);
// Destination buffer
size_t dstBuffSiz = srcBuffSiz + 128;
unsigned char* dstBuff = new unsigned char[dstBuffSiz];
memset(dstBuff, 0x00, dstBuffSiz);
unsigned char keyPtr[kCCKeySizeAES128] = { 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09, 0x0A, 0x0B, 0x0C, 0x0D, 0x0E, 0x0F, 0x10};
size_t bytesEncrypted = 0;
CCCryptorStatus cryptStatus = CCCrypt(kCCEncrypt, kCCAlgorithmAES128, kCCOptionPKCS7Padding,
keyPtr, kCCKeySizeAES128,
NULL /* initialization vector (optional) */,
srcBuff, srcBuffSiz, /* input */
dstBuff, dstBuffSiz, /* output */
&bytesEncrypted);
因此,在这两种情况下,我都尝试使用预定义的示例密钥来加密示例 1024 字节缓冲区(之前填充了 0x01 值)。
iOS 中第一个和最后 6 个字节的加密缓冲区:
ED CC 64 27 A8 99 ... 0C 44 9F EC 34 FC
Android 中第一个和最后 6 个字节的加密缓冲区:
AE 65 A9 F7 7F 0E ... 1F BD AE 8B 85 ED
有什么想法吗?
如果我将 Cipher.getInstance("AES/CBC/PKCS7Padding") 替换为 Cipher.getInstance("AES"),那么加密缓冲区的前几个字节将是相同的,但从第 17 个字节开始......
iOS:
ED CC 64 27 A8 99 DA 83 D5 4A B0 03 0F E7 DD A7 35 F2 50 5C 49 47 CC 3B 2F AB D1 61 05
安卓:
ED CC 64 27 A8 99 DA 83 D5 4A B0 03 0F E7 DD A7 ED CC 64 27 A8 99 DA 83 D5 4A B0 03 0F
【问题讨论】:
-
你试过解密另一部手机的结果吗?比如说,android解密iOS结果,iOS试试Android结果?
-
不,我没有。我认为加密结果应该是一样的。
-
unsigned char array VS a byte array..你不觉得这些之间有什么不同吗? :)
-
您应该尝试解密这些结果以查看它们是否相同。因为即使您使用相同的密钥进行加密,结果也可能不同。这就是加密的目的。如果每次你使用相同的键得到相同的结果,它就不是碰撞安全的。看到这个:stackoverflow.com/questions/11818684/…
-
ss1271:我的代码中没有使用任何盐,所以结果不会不同。