PHP 使用 openssl 扩展实现公钥加密

时间:2022-10-29 15:48:13

使用 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('openssl'));

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

// 明文数据
$data = 'test-string!';

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


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


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