关于手册中 openssl_private_encrypt 的 [P.Peyremorte] 的注释的一点补充。
“- openssl_private_encrypt 每次最多可以加密 117 个字符。”
这取决于 $key 的长度
- 对于 1024 位密钥长度 => 最多可加密的字符(字节)数 = 1024/8 - 11(使用填充时)= 117 个字符(字节)。
- 对于 2048 位密钥长度 => 最多可加密的字符(字节)数 = 2048/8 - 11(使用填充时)= 245 个字符(字节)。
... 等等
顺便说一句,如果 openssl_private_encrypt 由于数据大小而失败,您将一无所获,只会返回 false,openssl_public_decrypt() 在解密时也是如此。
“- 加密后的输出字符串始终为 129 个字符长度。如果您对加密后的输出使用 base64_encode,它将始终给出 172 个字符,最后一个始终为“=”(填充)”
这再次取决于 $key 的长度
- 对于 1024 位密钥长度 => 加密后的原始字节数始终是 RSA 设计的 128 字节(1024 位)块。
- 对于 2048 位密钥长度 => 加密后的原始字节数始终是 RSA 设计的 256 字节(2048 位)块。
... 等等
关于 base64_encode 输出长度,它取决于您编码的内容(意味着它取决于加密后产生的字节),但通常生成的编码字符串大约会大 33%(对于 128 字节大约为 170 字节,对于 256 字节大约为 340 字节)。
然后,我将通过以下方式稍微概括一下 [P.Peyremorte] 的注释
<?php
private $ENCRYPT_BLOCK_SIZE = 200;private $DECRYPT_BLOCK_SIZE = 256;function encrypt_RSA($plainData, $privatePEMKey)
{
$encrypted = '';
$plainData = str_split($plainData, $this->ENCRYPT_BLOCK_SIZE);
foreach($plainData as $chunk)
{
$partialEncrypted = '';
$encryptionOk = openssl_private_encrypt($chunk, $partialEncrypted, $privatePEMKey, OPENSSL_PKCS1_PADDING);
if($encryptionOk === false){return false;}$encrypted .= $partialEncrypted;
}
return base64_encode($encrypted);}
protected function decrypt_RSA($publicPEMKey, $data)
{
$decrypted = '';
$data = str_split(base64_decode($data), $this->DECRYPT_BLOCK_SIZE);
foreach($data as $chunk)
{
$partial = '';
$decryptionOK = openssl_public_decrypt($chunk, $partial, $publicPEMKey, OPENSSL_PKCS1_PADDING);
if($decryptionOK === false){return false;}$decrypted .= $partial;
}
return $decrypted;
}
?>