繁体   English   中英

PHP:使用OpenSSL加密和解密时出错

[英]PHP: error when encrypting and decrypting with openSSL

我一直在尝试制作两个PHP页面,一个进行加密,另一个进行解密。

加密页面的代码:

<form action="encrypt.php" method="post">
<input type="text" name="data">
<input type="submit">
</form>

<?php
    if($_SERVER["REQUEST_METHOD"] == "POST")
    {
        $config = array(
                "digest_alg" => "sha512",
                "private_key_bits" => 4096,
                "private_key_type" => OPENSSL_KEYTYPE_RSA,
                );
        $keys = openssl_pkey_new($config);
        openssl_pkey_export($keys, $privKey);    
        $pubKey = openssl_pkey_get_details($keys);
        $pubKey = $pubKey["key"];

        require "openssl.php";
        openssl_public_encrypt($_POST["data"],$encrypted, $pubKey);
        echo $encrypted;
        echo "<br><br>";
        echo $privKey;
    }

    ?>

这是解密的代码:

<form action="decrypt.php" method="post">
Encrypted Text: <textarea name="encrypted" rows="10" cols="100"></textarea><br><br>
Key: <textarea name="key" rows="10" cols="100"></textarea><br>
<input type="submit">
</form>

<?php
    if($_SERVER["REQUEST_METHOD"] == "POST")
    {
        openssl_private_decrypt($_POST["encrypted"],$decrypted,$_POST["key"]);
        echo $decrypted;
    }
?>

似乎可以很好地加密数据,但是当我尝试使用其他页面解密时,出现错误:

openssl_private_decrypt()[function.openssl-private-decrypt]:密钥参数不是有效的私钥

我直接从加密文件的输出中复制并粘贴了私钥。 为什么会出现错误?

似乎可以加密数据了,

要调试的第一件事:您可以立即在加密页面上解密加密的消息并获得相同的纯文本消息吗?

openssl_private_decrypt()[function.openssl-private-decrypt]:密钥参数不是有效的私钥

您的代码包含:

 openssl_private_decrypt($_POST["encrypted"],$decrypted,$_POST["key"]); 

尝试以下方法:

$private = openssl_pkey_get_private($_POST['key']);
openssl_private_decrypt($_POST["encrypted"], $decrypted, $private);

关于安全性的一句话 :OpenSSL的RSA加密默认设置不安全

为了获得最佳结果,在任何需要公钥加密的现实应用程序中,请考虑切换到libsodium并仅使用crypto_box_seal API

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM