Maison > Article > développement back-end > Explication détaillée de la méthode d'implémentation de Hello Word pour le développement d'extensions PHP7
Cet article présente principalement la méthode d'implémentation de hello word dans le développement d'extensions PHP7. Il analyse les étapes spécifiques et les techniques de fonctionnement associées au développement d'extensions PHP7 sous forme d'exemples. Il implique la modification et la compilation du code source sous-jacent de PHP. . Les amis dans le besoin peuvent se référer à ce qui suit
L'exemple dans cet article décrit la méthode d'implémentation de hello word dans le développement d'extensions PHP7. Partagez-le avec tout le monde pour votre référence, les détails sont les suivants :
Voici basé sur PHP7, expliquant comment créer une extension PHP à partir de zéro. Cet article explique principalement 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émentez une méthode say dans l'extension Après avoir appelé la méthode say, le mot bonjour est affiché.
Première étape : Générer du code
PHP nous fournit l'outil pour générer du code de base ext_skel. 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.
dnl If your extension references something external, use with: dnl PHP_ARG_WITH(say, for say support, dnl Make sure that the comment is aligned: dnl [ --with-say Include say support]) dnl Otherwise use enable: dnl PHP_ARG_ENABLE(say, whether to enable say support, dnl Make sure that the comment is aligned: dnl [ --enable-say Enable say support])
Où, dnl est le symbole d'annotation. 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 du code associé PHP_ARG_WITH. Sinon, supprimez les commentaires du segment de code PHP_ARG_ENABLE pertinent. 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 If your extension references something external, use with: dnl PHP_ARG_WITH(say, for say support, dnl Make sure that the comment is aligned: dnl [ --with-say Include say support]) dnl Otherwise use enable: PHP_ARG_ENABLE(say, whether to enable say support, Make sure that the comment is aligned: [ --enable-say Enable say support])
La troisième étape, la mise en œuvre du code
Modifiez le fichier say.c. Implémentez la méthode say.
Trouvez PHP_FUNCTION(confirm_say_compiled)
et ajoutez le code suivant au-dessus :
PHP_FUNCTION(say) { zend_string *strg; strg = strpprintf(0, "hello word"); RETURN_STR(strg); }
Trouvez PHP_FE(confirm_say_compiled
et ajoutez le code suivant au-dessus :
PHP_FE(say, NULL)
Le code modifié est le suivant :
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[] */ }; /* }}} */
La quatrième étape, compiler et installer
Les étapes pour compiler l'extension sont les suivantes :
$ phpize $ ./configure $ make && make install
Modifiez le fichier php.ini, ajoutez le code suivant :
[say] extension = say.so
puis exécutez la commande php -m
. Dans le contenu de sortie, vous verrez le mot dire.
La cinquième étape consiste à appeler le test
Écrivez vous-même un script et appelez la méthode say. Vérifiez si le contenu de sortie est comme prévu.
La particularité de la balise volist dans thinkphp dans les opérations ajax
Explication détaillée de la balise volist dans thinkphp
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!