gpt4 book ai didi

php - Xcode AES 加密/解密 - php 兼容性问题

转载 作者:行者123 更新时间:2023-11-29 11:01:25 24 4
gpt4 key购买 nike

我正在尝试在 Xcode 中加密一个字符串并用 PHP 解密,或者用 PHP 加密并用 Xcode 解密。

所以首先我试图获得相同的AES 加密 结果。

这是我的 Xcode 文件(为简单起见,我将所有内容都放在一个文件中):

#import "t.h"
#import <CommonCrypto/CommonCryptor.h>

@interface NSData(AES)
- (NSData*)AES256EncryptWithKey:(NSString*)key;
- (NSData*)AES256DecryptWithKey:(NSString*)key;
@end

@implementation NSData (AES)

- (NSData*)AES256EncryptWithKey:(NSString*)key {
char keyPtr[kCCKeySizeAES256];

[key getCString:keyPtr maxLength:sizeof(keyPtr) encoding:NSASCIIStringEncoding];

NSString *iv = @"1234567812345678";
char ivPtr[kCCKeySizeAES128];

[iv getCString:ivPtr maxLength:sizeof(ivPtr) encoding:NSASCIIStringEncoding];

NSUInteger dataLength = [self length];

size_t bufferSize = dataLength + kCCBlockSizeAES128;
void* buffer = malloc(bufferSize);

size_t numBytesEncrypted = 0;
CCCryptorStatus cryptStatus = CCCrypt(kCCEncrypt, kCCAlgorithmAES128, NULL,
keyPtr, kCCKeySizeAES256,
ivPtr /* initialization vector (optional) */,
[self bytes], dataLength, /* input */
buffer, bufferSize, /* output */
&numBytesEncrypted);

if (cryptStatus == kCCSuccess)
{
return [NSData dataWithBytesNoCopy:buffer length:numBytesEncrypted];
}

free(buffer); //free the buffer;
return nil;
}

- (NSData*)AES256DecryptWithKey:(NSString*)key {
char keyPtr[kCCKeySizeAES256];

NSString *iv = @"1234567812345678";
char ivPtr[kCCKeySizeAES128];

[iv getCString:ivPtr maxLength:sizeof(ivPtr) encoding:NSASCIIStringEncoding];


// fetch key data
[key getCString:keyPtr maxLength:sizeof(keyPtr) encoding:NSASCIIStringEncoding];

NSUInteger dataLength = [self length];

size_t bufferSize = dataLength + kCCBlockSizeAES128;
void* buffer = malloc(bufferSize);

size_t numBytesDecrypted = 0;
CCCryptorStatus cryptStatus = CCCrypt(kCCDecrypt, kCCAlgorithmAES128, NULL,
keyPtr, kCCKeySizeAES256,
ivPtr /* initialization vector (optional) */,
[self bytes], dataLength, /* input */
buffer, bufferSize, /* output */
&numBytesDecrypted);

if (cryptStatus == kCCSuccess)
{
return [NSData dataWithBytesNoCopy:buffer length:numBytesDecrypted];
}

free(buffer); //free the buffer;
return nil;
}

@end



@interface t ()
@end

@implementation t

- (void)viewDidLoad
{
[super viewDidLoad];


NSString *key = @"12345678123456781234567812345678";

NSData *plaintext = [[@"aaa0000000000000" dataUsingEncoding:NSASCIIStringEncoding] AES256EncryptWithKey: key];

label1.text = [[NSString alloc] initWithData:plaintext encoding:NSASCIIStringEncoding];


}

@end

现在是 PHP 代码:

<?php

$key256 = "12345678123456781234567812345678";
$iv128 = "1234567812345678";
$text = "aaa";

$blocksize = 16;
$len = strlen($text);
$pad = $blocksize - ($len % $blocksize);

$text .= str_repeat("0", $pad);

$cipher = mcrypt_encrypt(MCRYPT_RIJNDAEL_128, $key256, $text, MCRYPT_MODE_CBC, $iv128);

echo $cipher;

?>

Xcode加密字符串和php加密字符串不一样

PHP:â5¢Ð[Iüf#hÂ(Æ

Xcode: ¡#yZPbEs¿D6ñ

我该怎么做才能让它发挥作用?我做错了什么吗?

我将进一步解释代码的作用及其结构,以便您更容易理解问题(如果我错了请纠正我):

  1. PHP 和 Xcode 都使用 CBC 进行 AES 加密,所以我想这没有问题。

  2. 如您所见,我只是想获得相同的结果 - 安全在这里并不重要 - 所以我没有使用填充 - 文本的长度正好是 128 位(16 个字符)。

  3. key 为 256 位(32 个字符)。

  4. 初始化向量为 128 位(16 个字符)。

非常感谢。

感谢任何帮助!

最佳答案

终于明白了! (在询问 Apple 之后)

显然从 NSString 获取 getCString 是错误的,因为例程试图以 null 终止字符串,而 32 字节的缓冲区不足以终止 32 字符的字符串。

获取 key 或 IV 的正确方法是:

[key cStringUsingEncoding:NSASCIIStringEncoding];

关于php - Xcode AES 加密/解密 - php 兼容性问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15752959/

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