RNCryptor iOS/PHP и специальные символы

Я использую RNCryptor для шифрования сообщения в iOS, а затем расшифровываю его в PHP. Однако специальные символы исчезают из расшифрованной строки.

Как я шифрую в iOS

-(NSData *)encryptThis:(NSString *)str

{

NSString *key = @"mysuper32bitkey";
NSError *error = nil;
NSData *data = [str dataUsingEncoding:NSUTF8StringEncoding];
NSData *encryptedData = [RNEncryptor encryptData:data
                                    withSettings:kRNCryptorAES256Settings
                                        password:key
                                           error:&error];

return encryptedData;

}

Как я расшифровываю в PHP

$b64_data = $message;
$password = "mysuper32bitkey"
// back to binary
$bin_data = $message;// message already in binary. No need for -> mb_convert_encoding($b64_data, "UTF-8", "BASE64");
// extract salt
$salt = substr($bin_data, 2, 8);
// extract HMAC salt
$hmac_salt = substr($bin_data, 10, 8);
// extract IV
$iv = substr($bin_data, 18, 16);
// extract data
$data = substr($bin_data, 34, strlen($bin_data) - 34 - 32);
// extract HMAC
$hmac = substr($bin_data, strlen($bin_data) - 32);

// make HMAC key
$hmac_key = pbkdf2('SHA1', $password, $hmac_salt, 10000, 32, true);
// make HMAC hash
$hmac_hash = hash_hmac('sha256', $data , $hmac_key, true);
// check if HMAC hash matches HMAC
if($hmac_hash != $hmac)
    echo "false";

// make data key
$key = pbkdf2('SHA1', $password, $salt, 10000, 32, true);
// decrypt
$ret = mcrypt_decrypt(MCRYPT_RIJNDAEL_128, $key, $data, MCRYPT_MODE_CBC, $iv);

echo trim(preg_replace('/[\x00-\x08\x0B\x0C\x0E-\x1F\x80-\xFF]/u', '', $ret));

Дело в том, что если я зашифрую «Agresión» в iOS, PHP вернет только «Agresin». Почему он не расшифровывает «у»? Я думал, что dataUsingEncoding:NSUTF8StringEncoding сохранит специальные символы... Должен ли я использовать другой тип кодирования?


person GabCas    schedule 14.03.2013    source источник


Ответы (1)


Вы удаляете ó (U+00F3) в этой строке:

echo trim(preg_replace('/[\x00-\x08\x0B\x0C\x0E-\x1F\x80-\xFF]/u', '', $ret));

Обратите внимание, что вы удаляете все файлы \x80-\xFF. Не делай этого.

person Rob Napier    schedule 14.03.2013
comment
так и должно быть: echo trim(preg_replace('/[\x00-\x08\x0B\x0C\x0E-\x1F/u','',$ret)); ? Удаление \x80-\xFF - person GabCas; 15.03.2013
comment
Зачем ты здесь вырезаешь персонажей? - person Rob Napier; 19.03.2013
comment
Это было из примера без комментариев. Теперь я понимаю, что удалял много символов Юникода. - person GabCas; 20.03.2013
comment
Я случайно знаю код, который вы копировали. Первоначальный автор игнорировал HMAC. Что он сделал, так это обработал HMAC, как если бы это был зашифрованный текст, и просто расшифровал его. Затем он предположил, что ни один из HMAC не будет расшифровывать символы ASCII (не лучшая ставка), поэтому он удалил все не-ASCII в окончательной строке. Правильное решение состоит в том, чтобы извлечь и проверить HMAC, как вы это делаете. - person Rob Napier; 20.03.2013