English | 简体中文 | 繁體中文 | Русский язык | Français | Español | Português | Deutsch | 日本語 | 한국어 | Italiano | بالعربية
PHP OpenSSL Функциональное руководство
Функция openssl_pkey_export_to_file() используется для экспорта ключа в файл.
openssl_pkey_export_to_file()Функция экспортирует ключ в файл.
Функция openssl_pkey_export_to_file() сохраняет ключ в файле в формате PEM, PEM означает Privacy-Enhanced Mail,主要用于存储加密密钥和证书。
openssl_pkey_export_to_file ( mixed $key , string $outfilename [, string $passphrase [, array $configargs ] ] ) : bool
Номер | Параметр | Описание |
---|---|---|
1 | key | Ключ, который нужно экспортировать в файл. |
2 | outfilename | outfilename - это путь для сохранения файла .pem. |
3 | passphrase | Пароль для защиты файла. |
4 | configargs | Параметр configargs - это детальная информация о конфигурации, предоставляемая функции для генерации пары私ных/публичных ключей. Подробности см. ниже. |
По умолчанию openssl_pkey_new() использует конфигурационные детали,存在的 openssl.cnf. Но с помощью configargs можно их заменить. Детали конфигурации такие как:
configargs | Тип | Ключ, используемый в openssl.conf | Описание |
---|---|---|---|
digest_alg | Строка | default_md | Сокращение метода, которое вы получите из openssl_get_md_methods(). |
x509_extensions | Строка | x509_extensions | Расширение, используемое при создании x509 сертификата. |
req_extensions | Строка | req_extensions | Расширение, используемое при создании CSR. |
private_key_bits | Целое число | default_bits | Указать количество бит, используемых для генерации私ного ключа. |
private_key_type | Целое число | none | Тип私ного ключа, который нужно создать. Это может быть одним из OPENSSL_KEYTYPE_DSA, OPENSSL_KEYTYPE_DH, OPENSSL_KEYTYPE_RSA или OPENSSL_KEYTYPE_EC. по умолчанию это OPENSSL_KEYTYPE_RSA. |
encrypt_key | Булево значение | encrypt_key | Была ли зашифрована экспортированная ключ? |
encrypt_key_cipher | Целое число | none | Парольные константы, например OPENSSL_CIPHER_RC2_40 (целое число), OPENSSL_CIPHER_RC2_128 (целое число), OPENSSL_CIPHER_RC2_64 (целое число), OPENSSL_CIPHER_DES (целое число), OPENSSL_CIPHER_3DES (целое число) и т.д. |
curve_name | Строка | none | Одним из имен кривых, возвращаемых функцией openssl_get_curve_names(). |
config | Строка | N/A | Вы можете изменить конфигурацию в openssl.conf по необходимости и указать его путь здесь. |
Функция PHP openssl_pkey_export_to_file() возвращает true, если успешна, в противном случае false.
Эта функция начнет работать с версии PHP более 5.0.0.
Работа функции openssl_pkey_export_to_file():
<?php //Создание частного ключа $privkey = openssl_pkey_new(); openssl_pkey_export_to_file($privkey, 'C:/xampp/htdocs/modules/openssl/keytest.pem'); ?>
С详细信息, хранящиеся в файле keytest.pem, следующие:
-----BEGIN PRIVATE KEY----- MIIEvgIBADANBgkqhkiG9w0BAQEFAASCBKgwggSkAgEAAoIBAQDaqNK97A+mL9Xu IDt3rz9yfFUvrLcDEvsDa9JsjQByJVbdRtaNl6nfg91/LfKO8zAeG8srd292jcYk 9MgBhkpMCHvF/QhWjA4IdPLdWHCbYfjF/LHmo/z022/FqTnjQtFws992/ClhZdo6 kpDlU/H2lmbnCwrsqHlqcQ7bzBgC5U5SW0t3A03PSqxQTIFPOHi1Yx1Il5jH/H11 6UXDKogAWsseRpdwVdsCy6Wj3rkybr1pr7CDkHSS49MAvJ4e6xhs+je12lrtyChR ZTIYLICzEG7a1n0BPGAI1bQcivHXNipUkAYFn221gKRuB+9SQvC3VKbNXy8Oc7N9 HEahD8S3AgMBAAECggEBAKzEU68og7zlcvzxjsskNtd4kb5Xk0rkhlzPprWKO131 TssLm57IxLoMcMh6P3rff5dqkn9HoVRk9LhiiF1cA/xLf7CSGzJ2+ueHsBVgOaks IeodnVsFG2tEru3YphqAwwdvuBNFblS8q084WzA3waj6cVgAi6MuArEtn3XfruEp Yryc4Y1I1SB92x4y85tZ/PcomumPH0djKQeuhzy7f7GloJRfdshNENRbkdLc65N5 j8hy7WxMSa0dpJ3ZJMmgNfek9nALntSZfOsHGMZ/Wog8eV6+HzCwqqrMkR15pZI1 HqvVszU1iwoUJvlGoxInJOqJ2c6lBSBOBBR8DuuQixECgYEA+8RKXcw0U3VU8zJO NTFzSDEtFYKZ5Bg4IPaYSTSo/ojiL3VrLeocRq3/2zdeCw8wx9eNZbcBW93lWVxK q2G0X4XgonorEEONBvL9aE/D7wBCMYPWDXd/KQVZW8CPwcy10g2oIi3SqbcTQ/gT fcmcHAQD2wVgo9XBlg24ESAP01MCgYEA3lYGasOvDweca5GCiP4m1oOH605haIUU f5CDWXbZ6QjcoUQQB0CoDtTl3QpBd3KGbd+PbqU8xb44+LhrVIsjUyZs6k+eLACe Dufzq00mIRSl/TZ0R3q17lAMmxId9QramDScpmqqqXonpOpdEoonThynhLyANgX3 eYGLXeqaII0CgYBPVi/JFwx2MEcwy+1xPcACQ9zdJmawRiGJ4atjhkCq1R/RrMK1 mUyHyVUTE4ODIKpSj05zexPmiyo22qp9DzDz2RBMowrm+SJ7yh6ovFoV+pLhX5YY cEuV9aWPEEM84vF42+zbuGzmJlbf2FDsFpgnC+zbG/q0Jiv2ySPz4ZKbGQKBgQDM ek9ih1+LshNAts1Xkm5DoSoy1Z4uUx48B7tVX0If2N+YjRE0qlklctWIiXMWGMTb bdzrBJq0vjKFRI6pbWFqio9mmxy8GUFEMjzekZB8ohHao+cjCg8iAorlXy8f+wB5 NQHQ547XWRn2yPgaIebuJtpF8Fr11Fz6aZK0KBvhzQKBgGRwuxq6IhIROupoDRpU RHuqICeQQYcf7Cfk7+ZyYJnA1fbOowj4Q5zvbWa6N2Ygyq2KIl0P5YL4Atb7aRKS e6ol8lIKZM9ysbS+wR0OhhTJs/9CqpgvDbYNQFiaVZtGRpSNCxHkhn0cAR7lzK4P ROQC7p9zXJhAmzE8/hTD9eaH -----END PRIVATE KEY-----
Получение ключа из файла .pem-
<?php //Создание частного ключа $privkey = openssl_pkey_new(); openssl_pkey_export_to_file($privkey, 'C:/xampp/htdocs/modules/openssl/keytest.pem'); //Использование файла .pem с частным ключом. $testprivatekey = openssl_get_privatekey(file_get_contents('C:/xampp/htdocs/modules/openssl/keytest.pem')); if ($testprivatekey === false) { var_dump(openssl_error_string()); } else { //var_dump($testprivatekey); $key_details = openssl_pkey_get_details($testprivatekey); print_r($key_details["key"]); } ?>
Подробные данные, хранящиеся в файле test-csr1.pem, следующие:
-----BEGIN PUBLIC KEY----- MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAnbGAblUCP6sZvbi2JM4G PcLmKK9flGQq6EE+yvMWrEUnIPGOLJUEB06dE8inIMQTYDmdmjn7HgUAlIDaViw+ aSv3XBZJqBTm7xtW4488oKuCzdBuJbnomtGttFWOk4cjb8kG+Kza6v0AB+P0eUru cPkwnJF4F1pGY1pszSMsL3/s7OcIzjiKUKu5vHJxUWO7baVovq+gv9+O24Pd0GhB t6RC/pgK/42YqZ2YW5V+JiuCFFkTVPusviunAOLLpDwoyPIROvXdML2TKopiowOd nmOkNRrW81duRF8Z4dcn7jnf2sKExpLBgAtcV05OufZIv3VeeTD0ISbCJhn0zmx/ SQIDAQAB -----END PUBLIC KEY-----