English | 简体中文 | 繁體中文 | Русский язык | Français | Español | Português | Deutsch | 日本語 | 한국어 | Italiano | بالعربية

Tutoriel PHP de base

Tutoriel PHP avancé

PHP & MySQL

Manuel de référence PHP

Utilisation et exemple de la fonction openssl_pkey_export_to_file() en PHP

PHP OpenSSL Fonction Manual

La fonction openssl_pkey_export_to_file() est utilisée pour exporter les clés vers un fichier.

Définition et utilisation

openssl_pkey_export_to_file()La fonction exporte les clés vers un fichier.

La fonction openssl_pkey_export_to_file() sauvegarde les clés au format PEM, où PEM signifie Privacy Enhanced Mail.-Enhanced Mail, principalement stocke les clés et certificats chiffrés.

Syntaxe

La syntaxe est openssl_pkey_export_to_file ( mixed $key , string $outfilename [, string $passphrase [, array $configargs ] ] ) : bool

Paramètres

NuméroParamètresDescription
1

key

La clé à exporter dans le fichier.

2

outfilename

outfilename est le chemin d'accès pour enregistrer le fichier .pem.

3

passphrase

Mot de passe pour protéger le fichier.

4

configargs

Les paramètres configargs doivent être fournis à la fonction pour générer la clé privée/Détails de configuration du couple de clés publique, détaillés comme suit.

Paramètres de configuration

Par défaut, openssl_pkey_new() utilise les détails de configuration existants dans openssl.cnf. Cependant, configargs peut les remplacer. Les détails de configuration sont les suivants :

configargsTypeClés utilisées dans openssl.confDescription
digest_algChaînedefault_mdLes méthodes de résumé obtenues par openssl_get_md_methods().
x509_extensionsChaînex509_extensionscréer_x509L'extension utilisée lors de la création du certificat.
req_extensionsChaînereq_extensionsL'extension utilisée lors de la création du CSR.
private_key_bitsentierdefault_bitsSpécifiez le nombre de bits à utiliser lors de la génération de la clé privée.
private_key_typeentiernoneLe type de clé privée à créer. Il peut s'agir d'une des valeurs OPENSSL_KEYTYPE_DSA, OPENSSL_KEYTYPE_DH, OPENSSL_KEYTYPE_RSA ou OPENSSL_KEYTYPE_EC. La valeur par défaut est OPENSSL_KEYTYPE_RSA.
encrypt_keybooléenencrypt_keyEst-ce que la clé exportée est chiffrée?
encrypt_key_cipherentiernoneConstante de mot de passe, par exemple OPENSSL_CIPHER_RC2_40 (entier), OPENSSL_CIPHER_RC2_128(entier), OPENSSL_CIPHER_RC2_64(entier), OPENSSL_CIPHER_DES (entier), OPENSSL_CIPHER_3DES (entier) et autres.
curve_nameChaînenoneL'un des noms de courbes renvoyés par la fonction openssl_get_curve_names().
configChaîneN/AVous pouvez modifier la configuration dans openssl.conf selon vos besoins et fournir son chemin ici.

返回值

PHP openssl_pkey_export_to_file()函数如果成功则返回true,否则返回false。

PHP版本

此函数将从大于5从PHP版本0.0开始工作。

Instance1

openssl_pkey_export_to_file()函数的工作-

<?php
        //Créer la clé privée
	$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 PRIVÉ KEY-----

Instance2

Obtenir la clé à partir du fichier .pem-

<?php
        //Créer la clé privée
	$privkey = openssl_pkey_new();
	openssl_pkey_export_to_file($privkey, 'C:/xampp/htdocs/modules/openssl/keytest.pem');
	//Utilisez un fichier .pem avec la clé privée.
	$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"]);	
	}
?>

stocké dans le fichier test-csr1Détails suivants dans .pem-

-----BEGIN PUBLIC KEY-----
MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAnbGAblUCP6sZvbi2JM4G
PcLmKK9flGQq6EE+yvMWrEUnIPGOLJUEB06dE8inIMQTYDmdmjn7HgUAlIDaViw+
aSv3XBZJqBTm7xtW4488oKuCzdBuJbnomtGttFWOk4cjb8kG+Kza6v0AB+P0eUru
cPkwnJF4F1pGY1pszSMsL3/s7OcIzjiKUKu5vHJxUWO7baVovq+gv9+O24Pd0GhB
t6RC/pgK/42YqZ2YW5V+JiuCFFkTVPusviunAOLLpDwoyPIROvXdML2TKopiowOd
nmOkNRrW81duRF8Z4dcn7jnf2sKExpLBgAtcV05OufZIv3VeeTD0ISbCJhn0zmx/
SQIDAQAB
-----END PUBLIC KEY-----

PHP OpenSSL Fonction Manual