문자열 (0, 1, 2, ...)을 문자열로 인코딩 할 암호화/암호 해독 기능을 찾고 있습니다. 이러한 문자열은 무작위로 보이고 나중에 문자열에서 암호를 해독 할 수 있습니다.문자열에서 코드 번호를 지정하고 나중에 코드를 디코딩하는 방법은 무엇입니까?
예 : 3은 ABFQWEMasdEE로 암호화되고 6은 poad_Asd # @ sad로 암호화됩니다.
암호화 된 문자열의 문자 수와 거기에 나타날 수있는 문자를 제어 할 수 있다면 좋을 것입니다.
UPDATE I이 용액 결국
:
<?php
$key = 'secret_password';
for ($i = 100; $i < 110; $i++) {
$text = "$i";
$encrypted = encrypt($text, $key);
$decrypted = decrypt($encrypted, $key);
$decrypted = rtrim($decrypted, "\0");
$ok = ($text === $decrypted);
if (!$ok) {
exit('********** BUG BUG BUG BUG BUG ***********');
}
echo '[' . $text . '] [' . $encrypted . '] [' . $decrypted . '] ' . ($ok ? 'OK' : 'BUG BUG BUG BUG BUG BUG BUG') . '<br />';
}
exit('***** OK ******');
function encrypt($data, $key) {
$td = mcrypt_module_open('cast-256', '', 'ecb', '');
$iv = mcrypt_create_iv(mcrypt_enc_get_iv_size($td), MCRYPT_RAND);
mcrypt_generic_init($td, $key, $iv);
$encrypted_data = mcrypt_generic($td, $data);
mcrypt_generic_deinit($td);
mcrypt_module_close($td);
return base64_encode($encrypted_data);
}
function decrypt($encoded_64, $key) {
$td = mcrypt_module_open('cast-256', '', 'ecb', '');
$iv = mcrypt_create_iv(mcrypt_enc_get_iv_size($td), MCRYPT_RAND);
mcrypt_generic_init($td, $key, $iv);
$decrypted_data = mdecrypt_generic($td, base64_decode($encoded_64));
mcrypt_generic_deinit($td);
mcrypt_module_close($td);
return $decrypted_data;
}
?>
다음 출력 제공
[100] [9UA0Maq3MGp0CzMOWcpOpg ==] [100] OK
[101] [Y5WKH7J1 + k0bFqsGw1jmrA ==] OK
(210) [102] == NqV2opJc7CNq5O3lcuWKMw] [102] OK
[103] + 1FpJhHe vrK6aKA54VR53Q ==] [103] OK
[104] == MHQoYCqL4yCI9jKg1U0UYw] [104] OK
[105] [6Qq9aXEn46xpDgv8CvnK7Q ==] [105] OK
[106] [UGk1/byT7wpoFM59Uy/PDG ==] [106] OK
[107] == 39kyPA49zAZsCFx3pt6bYw] [107] OK
[108] == YccDSimEf3C0NKDaVOf4kA] 108] OK
[109] + PfmvLfVR4 gi9y9v/6efZQ ==] [109]
OK OK ***** ******
랜덤 문자열이 보인다 (제외한 0,123,303,399,341 끝에)와 같은 크기의 모든. 완벽한 솔루션은 아니지만 충분히 훌륭합니다!
감사합니다.
임의 길이 입력을 고정 길이 출력으로 변환하는 것은 일반적으로 암호화 기능이 아닌 * 해시 함수 *의 속성입니다. – deceze
해시 함수는 일반적으로 전체 효과가 아닙니다. 그는 되돌릴 수있는 것을 원한다. – Amadan
@Amadan 예. 가역 암호화는 일반적으로 고정 길이가 아닙니다. – deceze