Maison > Article > développement back-end > Apprenez étape par étape à créer une extension php (étapes de base)
Le contenu de cet article vise à vous apprendre étape par étape à créer une extension php (étapes de base). Elle a une certaine valeur de référence. Les amis dans le besoin peuvent s'y référer.
Quelles sont les étapes de base pour créer une extension. Dans l'exemple, nous allons implémenter les fonctions suivantes :
<?php echo say(); ?>
Contenu de sortie :
$ php ./test.php $ hello word
Implémenter une méthode say dans l'extension Après avoir appelé la méthode say, le mot bonjour sera. être émis.
Première étape : Générer du code
PHP nous fournit l'outil ext_skel pour générer du code de base. Cet outil se trouve dans le répertoire ./ext du code source PHP.
$ cd php_src/ext/ $ ./ext_skel --extname=say
La valeur du paramètre extname est le nom de l'extension. Après avoir exécuté la commande ext_skel, un répertoire avec le même nom d'extension sera généré dans le répertoire courant.
La deuxième étape consiste à modifier le fichier de configuration config.m4
La fonction de config.m4 est de coopérer avec l'outil phpize pour générer le fichier de configuration. Le fichier de configuration est utilisé pour la détection de l'environnement. Vérifiez si l'environnement requis pour la compilation et l'exécution de l'extension est rempli. Nous commençons maintenant à modifier le fichier config.m4.
$ cd ./say $ vim ./config.m4
Après avoir ouvert le fichier config.m4, vous trouverez ce paragraphe de texte.
dnl Si votre extension fait référence à quelque chose d'externe, utilisez avec :
dnl PHP_ARG_WITH(disons, par exemple, le support,
dnl Assurez-vous que le commentaire est aligné :
dnl [ - -with-say Inclure, par exemple, le support])
dnl Sinon, utilisez activate :
dnl PHP_ARG_ENABLE(par exemple, s'il faut activer, par exemple, le support,
dnl Assurez-vous que le commentaire est aligné :
dnl [ --enable-say Activer le support])
où dnl est le symbole de commentaire. Le code ci-dessus indique que si l'extension que vous écrivez dépend d'autres extensions ou bibliothèques lib, vous devez supprimer les commentaires sur le code associé à PHP_ARG_WITH. Sinon, décommentez la section de code associée à PHP_ARG_ENABLE. Les extensions que nous écrivons n'ont pas besoin de s'appuyer sur d'autres extensions et bibliothèques lib. Par conséquent, nous supprimons le commentaire devant PHP_ARG_ENABLE. Le code après suppression des commentaires est le suivant :
dnl Si votre extension fait référence à quelque chose d'externe, utilisez avec :
dnl PHP_ARG_WITH(disons, par exemple, support,
dnl Assurez-vous que le le commentaire est aligné ; le commentaire est aligné :
[ --enable-say Activer le support say])
La troisième étape consiste à implémenter le code
pour modifier le fichier say.c. Implémentez la méthode say.
Trouvez PHP_FUNCTION(confirm_say_compiled), ajoutez le code suivant au-dessus :
Trouvez PHP_FE(confirm_say_compiled), ajoutez le code suivant au-dessus :
Le code modifié est la suivante :
PHP_FUNCTION(say) { zend_string *strg; strg = strpprintf(0, "hello word"); RETURN_STR(strg); }
La quatrième étape, compiler et installer
PHP_FE(say, NULL)Les étapes pour compiler l'extension sont les suivantes :
const zend_function_entry say_functions[] = { PHP_FE(say, NULL) /* For testing, remove later. */ PHP_FE(confirm_say_compiled, NULL) /* For testing, remove later. */ PHP_FE_END /* Must be the last line in say_functions[] */ }; / }}} /Modifier le php.ini et ajoutez le code suivant :
Ensuite, exécutez la commande php -m Dans la sortie, vous verrez le mot say
$ phpize $ ./configure $ make && make installLa cinquième étape consiste à appeler le test <.>
Écrivez vous-même un script. Appelez la méthode say. Vérifiez si le contenu de sortie est comme prévu
[say] extension = say.soRecommandations associées :
[Redirection] Créez une classe en écrivant. votre propre extension PHP - orlion
Créez une extension PHP à partir de zéro
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!