rsa加解密

Posted xiaobiaomei

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了rsa加解密相关的知识,希望对你有一定的参考价值。

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

 

以上是关于rsa加解密的主要内容,如果未能解决你的问题,请参考以下文章

前后端RSA互相加解密加签验签密钥对生成(Java)

9.Java 加解密技术系列之 RSA

android md5加密与rsa加解密实现代码

Python3 - RSA双向加解密(详解)

Python3 - RSA双向加解密(详解)

Python3 - RSA双向加解密(详解)