Berikut adalah contoh script PHP untuk melakukan enkripsi dan dekripsi pada sebuah string menggunakan algoritma AES (Advanced Encryption Standard):
<?php
function encrypt($string, $key) {
$cipher = "AES-256-CBC";
$ivlen = openssl_cipher_iv_length($cipher);
$iv = openssl_random_pseudo_bytes($ivlen);
$ciphertext = openssl_encrypt($string, $cipher, $key, OPENSSL_RAW_DATA, $iv);
$hmac = hash_hmac('sha256', $ciphertext, $key, true);
return base64_encode($iv . $hmac . $ciphertext);
}
function decrypt($string, $key) {
$cipher = "AES-256-CBC";
$c = base64_decode($string);
$ivlen = openssl_cipher_iv_length($cipher);
$iv = substr($c, 0, $ivlen);
$hmac = substr($c, $ivlen, $sha2len = 32);
$ciphertext = substr($c, $ivlen + $sha2len);
$original_plaintext = openssl_decrypt($ciphertext, $cipher, $key, OPENSSL_RAW_DATA, $iv);
$calcmac = hash_hmac('sha256', $ciphertext, $key, true);
if (hash_equals($hmac, $calcmac)) {
return $original_plaintext;
}
return false;
}
?>
Pada contoh di atas, kita menggunakan algoritma AES-256-CBC untuk enkripsi dan dekripsi. Fungsi encrypt()
menerima string yang ingin dienkripsi dan kunci enkripsi, sedangkan fungsi decrypt()
menerima string terenkripsi dan kunci enkripsi.
Pastikan untuk mengganti nilai variabel $key
dengan kunci enkripsi yang aman dan tidak mudah ditebak. Selain itu, Anda juga dapat memodifikasi atau memperluas script ini sesuai dengan kebutuhan atau preferensi keamanan Anda.
Contoh penggunaannya:
<?php
// Contoh penggunaan
$plainText = "Ini adalah string yang akan dienkripsi";
$key = "KunciRahasia123";
$encryptedText = encrypt($plainText, $key);
echo "Teks Terenkripsi: " . $encryptedText . "\n";
$decryptedText = decrypt($encryptedText, $key);
echo "Teks Terdekripsi: " . $decryptedText . "\n";
?>
Hasilnya adalah:
Teks Terenkripsi: 3iqwCmHmQSIu/zCHaHByPPOlVn5JDOS6soyQqFVFsBRBnZfYnAbPqkLTEvANglBjyhcVSC8UUKlevk9dP9TATEm+KHAYw/DxewRxRU2aqF13A1qP5l91c2amvVem/ka4
Teks Terdekripsi: Ini adalah string yang akan dienkripsi