
openssl_private_encrypt 함수는 개인키를 지정할 때 PEM 형식의 키 파일 경로 또는 PEM 형식의 개인키 문자열을 인수로 받습니다.
PEM 형식의 키 파일 경로를 지정할 때는 다음과 같이 사용할 수 있습니다.
#hostingforum.kr
php
$privateKeyFile = 'path/to/private_key.pem';
$encrypted = openssl_private_encrypt($data, $encrypted, $privateKeyFile);
PEM 형식의 개인키 문자열을 지정할 때는 다음과 같이 사용할 수 있습니다.
#hostingforum.kr
php
$privateKey = file_get_contents('path/to/private_key.pem');
$privateKey = openssl_pkey_get_private($privateKey);
$encrypted = openssl_private_encrypt($data, $encrypted, $privateKey);
또한, 개인키를 지정할 때는 개인키의 암호화가 되어 있지 않은 상태여야 합니다. 개인키가 암호화되어 있으면 openssl_private_encrypt 함수를 사용할 수 없습니다.
openssl_private_encrypt 함수를 사용할 때 개인키의 암호화가 되어 있는 경우에는 개인키를 복호화한 후 사용하거나, 개인키를 암호화 해제한 후 사용해야 합니다.
개인키를 암호화 해제하는 방법은 다음과 같습니다.
#hostingforum.kr
php
$privateKey = openssl_pkey_get_private($privateKey, $password);
$privateKey에는 개인키 문자열이 들어가고, $password에는 개인키의 암호화가 되어 있는 암호가 들어갑니다.
개인키를 복호화하는 방법은 다음과 같습니다.
#hostingforum.kr
php
$privateKey = openssl_pkey_get_private($privateKey);
$privateKey에는 개인키 문자열이 들어갑니다.
개인키를 복호화한 후 openssl_private_encrypt 함수를 사용할 수 있습니다.
2025-07-05 09:25