>  기사  >  백엔드 개발  >  공개 키 암호화를 구현하기 위해 openssl 확장을 사용하는 PHP에 대한 자세한 소개

공개 키 암호화를 구현하기 위해 openssl 확장을 사용하는 PHP에 대한 자세한 소개

黄舟
黄舟원래의
2017-03-15 09:20:411176검색

openssl 명령을 사용하여 공개 및 개인 키 생성

// 生成私钥
# openssl genrsa -out rsa_private_key.pem 1024
// 生成公钥
# openssl rsa -in rsa_private_key.pem -pubout -out rsa_public_key.pem


샘플 코드는 다음과 같습니다.

<?php
// openssl 扩展检测
var_dump(extension_loaded(&#39;openssl&#39;));

$prikey = openssl_pkey_get_private(file_get_contents(&#39;rsa_private_key.pem&#39;)); //私钥
$pubkey = openssl_pkey_get_public(file_get_contents(&#39;rsa_public_key.pem&#39;)); //公钥

// 明文数据
$data = &#39;test-string!&#39;;

/**
 * 可能会出的问题:Don&#39;t know how to get public key from this private key
 * 原因:PHP 的 openssl 扩展和 Apache 的不一致导致, 当然在命令行下运行程序则不会出现此问题
 */
// 公钥加密
$encrypt_data = &#39;&#39;;
openssl_public_encrypt($data, $encrypt_data, $pubkey);
$encrypt_data = base64_encode($encrypt_data);
echo $encrypt_data;
echo &#39;<br/>&#39;;


// ------------------------------------------------------------


// 私钥解密
$encrypt_data = base64_decode($encrypt_data);
openssl_private_decrypt($encrypt_data, $decrypt_data, $prikey);
var_dump($decrypt_data);



위 내용은 공개 키 암호화를 구현하기 위해 openssl 확장을 사용하는 PHP에 대한 자세한 소개의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.