openssl_public_decrypt

公開鍵でデータを復号する

説明

bool openssl_public_decrypt(
    string $data,
    #[\SensitiveParameter]string &$decrypted_data,
    OpenSSLAsymmetricKeyOpenSSLCertificatearraystring $public_key,
    int $padding = OPENSSL_PKCS1_PADDING
)

openssl_public_decrypt は、事前に openssl_private_encrypt で暗号化された data を復号し、それを decrypted_data に格納します。

これを使用するのは、例えばメッセージの作者が秘密鍵の所有者であるかどうかを調べる場合です。

パラメータ

data

decrypted_data

public_key

public_key は、 データの暗号化に使用した秘密鍵と対になる公開鍵である必要があります。

padding

padding には OPENSSL_PKCS1_PADDING あるいは OPENSSL_NO_PADDING が指定可能です。

戻り値

成功した場合に true を、失敗した場合に false を返します。

変更履歴

バージョン 説明
8.0.0 public_key は、 OpenSSLAsymmetricKey または OpenSSLCertificate クラスのインスタンスを受け入れるようになりました。 これより前のバージョンでは、 OpenSSL key または OpenSSL X.509 型のリソースを受け入れていました。

参考

  • openssl_private_encrypt
  • openssl_private_decrypt