gpt4 book ai didi

php - iOS : kCCDecodeError -4304

转载 作者:行者123 更新时间:2023-11-29 04:39:18 26 4
gpt4 key购买 nike

我使用此脚本加密 php 中的登录信息:

//PHP Code
function cypherAES128($plaintext, $key)
{
$iv_size = mcrypt_get_iv_size(MCRYPT_RIJNDAEL_128, MCRYPT_MODE_ECB);
$iv = mcrypt_create_iv($iv_size, MCRYPT_RAND);


$ciphertext = mcrypt_encrypt(MCRYPT_RIJNDAEL_128, $key, $plaintext, MCRYPT_MODE_ECB/*, $iv*/);
$ciphertext = base64_encode($ciphertext);

return $ciphertext;
}

function uncypherAES128($ciphertext, $key)
{
$iv_size = mcrypt_get_iv_size(MCRYPT_RIJNDAEL_128, MCRYPT_MODE_ECB);
$iv = mcrypt_create_iv($iv_size, MCRYPT_RAND);

$ciphertext = base64_decode($ciphertext);
$plaintext = mcrypt_decrypt(MCRYPT_RIJNDAEL_128, $key, $ciphertext, MCRYPT_MODE_ECB/*, $iv*/);
return $plaintext;
}

我在 iOS 应用程序中获取了加密密码,并尝试使用 FBEncryptorAES 对其进行解密。 .

如果登录名小于 16 个字符,我可以解密它。

//PHP Code
echo cypherAES128("aShortLogin", $key); //this encrypted login can be decrypted
echo cypherAES128("loginGreaterThan16Characters", $key); //this encrypted login cannot

当加密字大于 15 个字符时,我收到 kCCDecodeError -4304。

有点精确:听起来长登录可以在 PHP 脚本中加密然后解密,AND 加密然后使用 FBEncryptor 解密。仅 PHP 加密 => ObjectiveC 解密不起作用

请问有什么想法吗?我是 iOS 和密码学的初学者。

预先感谢,并对我糟糕的英语表示歉意。

[编辑]不确定问题仅出在 ObjectiveC 上,因为正如我所说,FBEncryptor 可以解码它自己编码的文本。

执行此代码时出现错误:

//Objective-C code:
NSString * decryptedLogin = [FBEncryptorAES decryptBase64String: encryptedLogin keyString:AESKey];

其中“encryptedLogin”= PHP 脚本返回的值。更改 AESKey 的值和长度似乎不起作用。 (AESKey = 与 PHP 中的 $key 相同的 key )尝试过 16 和 32 字节长度 key 。

我没有更改FBEncryptorAES中的代码,这里是decryptBase64String:

//Objective-C code
+ (NSData*)decryptData:(NSData*)data key:(NSData*)key iv:(NSData*)iv;
{
NSData* result = nil;

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

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

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

// do decrypt
size_t decryptedSize = 0;
CCCryptorStatus cryptStatus = CCCrypt(kCCDecrypt,
FBENCRYPT_ALGORITHM,
kCCOptionPKCS7Padding,
cKey,
FBENCRYPT_KEY_SIZE,
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;
}

字符串被转换为 Base64 字符串。我不认为转换是问题所在。

最佳答案

问题解决了!!!!

只需在我的 PHP 脚本中使用“MCRYPT_MODE_CBC”而不是“MCRYPT_MODE_ECB”。

//PHP Code: 
// $key must be 32 bytes
$key="32-AAAAAAAAAAAAAAAAAAAAAAAAAAAAA";


function cypherAES128($plaintext, $key)
{
$iv_size = mcrypt_get_iv_size(MCRYPT_RIJNDAEL_128, MCRYPT_MODE_CBC);
$iv = mcrypt_create_iv($iv_size, MCRYPT_RAND);


$ciphertext = mcrypt_encrypt(MCRYPT_RIJNDAEL_128, $key, $plaintext, MCRYPT_MODE_CBC/*, $iv*/);
$ciphertext = base64_encode($ciphertext);

return $ciphertext;
}

function uncypherAES128($ciphertext, $key)
{
$iv_size = mcrypt_get_iv_size(MCRYPT_RIJNDAEL_128, MCRYPT_MODE_CBC);
$iv = mcrypt_create_iv($iv_size, MCRYPT_RAND);

$ciphertext = base64_decode($ciphertext);
$plaintext = mcrypt_decrypt(MCRYPT_RIJNDAEL_128, $key, $ciphertext, MCRYPT_MODE_CBC/*, $iv*/);
return $plaintext;
}

似乎有 5 种使用 AES 加密的方法,而我的 iOS 代码/PHP 代码没有使用相同的方法。

感谢您的回答,希望对您有所帮助!

关于php - iOS : kCCDecodeError -4304,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10628643/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com