(PHP 4 >= 4.2.0, PHP 5, PHP 7, PHP 8)

openssl_pkey_get_privateПолучает закрытый ключ


Функция openssl_pkey_get_private() разбирает ключ private_key и подготавливает его к работе в других функциях.

Список параметров


Параметр private_key разрешается задавать следующим образом:

  1. Строка вида file://path/to/file.pem. Файл должен содержать кодированный в PEM сертификат или закрытый ключ (может содержать и то и другое).
  2. Секретный ключ в формате PEM.


Если ключ защищён паролем, то его надо указать в параметре passphrase.

Возвращаемые значения

Функция возвращает экземпляр класса OpenSSLAsymmetricKey или false, если возникла ошибка.

Список изменений

Версия Описание
8.0.0 В случае успешного выполнения функция возвращает экземпляр OpenSSLAsymmetricKey; раньше возвращался ресурс (resource) типа OpenSSL key.
8.0.0 Параметр private_key теперь принимает экземпляр OpenSSLAsymmetricKey или OpenSSLCertificate; раньше принимался ресурс (resource) типа OpenSSL key или OpenSSL X.509.
8.0.0 Параметр passphrase теперь принимает значение null.
add a note

User Contributed Notes 2 notes

kristof1 at mailbox dot hu
10 years ago
It's actually "file://key.pem" when you want to give a relative path using unix systems. It will be three '/' in case of absolute path (e.g "file:///home/username/..."). But this path consists of two '/' originated from "file://" and one '/' from the fact that home is a subfolder of the unix filesystem's root directory ("/home/username/..."). This two part will be concatenated and you will get three '/' characters following each other.

So you only have to concatenate "file://" with an existing path string in every case.
pablo dot siciliano at gmail dot com
3 years ago

If this function not work with pathname try with a file_get_contents of a key file.
To Top