PHP 5,3 부터 지원하는 openssl_encrypt 함수를 이용하면 문자열을 암호화, 복호화 함수를 만들 수 있습니다.

  <?php
function Encrypt($str$secret_key='secret key'$secret_iv='secret iv')
{
    
$key hash('sha256'$secret_key);
    
$iv substr(hash('sha256'$secret_iv), 032)    ;
    return 
str_replace("="""base64_encode( openssl_encrypt($str"AES-256-CBC"$key0$iv)) );
}

function 
Decrypt($str$secret_key='secret key'$secret_iv='secret iv')
{
    
$key hash('sha256'$secret_key);
    
$iv substr(hash('sha256'$secret_iv), 032);
    return 
openssl_decrypt( base64_decode($str), "AES-256-CBC"$key0$iv );
}

$str "안녕하세요. 하보니입니다.";
$secret_key "123456789";
$secret_iv "#@$%^&*()_+=-";

$encrypted Encrypt($str$secret_key$secret_iv);
echo 
"암호화 문자열 => " .$encrypted"<br />\n";
$decrypted Decrypt($encrypted$secret_key$secret_iv);
echo 
"복호화 문자열 => " .$decrypted"\n";

/*
    결과:
    암호화 문자열 => VUYxMHFQVWU5TG9KeWMrZlJhZjV3VkFJbTFHV DZERlhNeEpldW1GRVB0WjQyODdkRnFDTFhIa0UrWEEvb1VGbg
    복호화 문자열 => 안녕하세요. 하보니입니다.
*/
?>

  1. 궁금 2018.02.23 12:27 댓글주소 | 수정 | 삭제 | 댓글

    Encrypt함수에서 str_replace로 '=' 를 제거하신 이유는 뭐에요?

  2. 궁금1 2019.03.04 14:12 댓글주소 | 수정 | 삭제 | 댓글

    PHP Warning: openssl_decrypt(): IV passed is 32 bytes long which is longer than the 16 expected by selected chipher. 라고 표시되는데..

    $iv = substr(hash('sha256', $secret_iv), 0, 32);
    여기서 32를 16으로 바꾸면 복호화 할 때도 16으로 바꿔야하나요?