Comment implémenter le mot bonjour dans le développement d'extensions PHP7

小云云
Libérer: 2023-03-19 14:38:01
original
1795 Les gens l'ont consulté

Cet article présente principalement la méthode d'implémentation de hello word du développement d'extensions PHP7. Il analyse les étapes spécifiques et les techniques de fonctionnement associées du 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 qui en ont besoin peuvent s'y référer. J'espère que cela pourra aider tout le monde.

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();
?>
Copier après la connexion

Contenu de sortie :


$ php ./test.php
$ hello word
Copier après la connexion

En expansion, implémentez une méthode say dedans. 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
Copier après la connexion

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
Copier après la connexion

Après avoir ouvert le fichier config.m4, vous trouverez ce paragraphe de texte.


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])
Copier après la connexion

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])
Copier après la connexion

La troisième étape consiste à implémenter le code

modification du 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);
}
Copier après la connexion

Trouvez PHP_FE(confirm_say_compiled et ajoutez le code suivant au-dessus :


PHP_FE(say, NULL)
Copier après la connexion

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[] */
 };
 /* }}} */
Copier après la connexion

La quatrième étape, compiler et install

Les étapes pour compiler l'extension sont les suivantes :


$ phpize
$ ./configure
$ make && make install
Copier après la connexion

Modifiez le fichier php.ini et ajoutez le code suivant :


[say]
extension = say.so
Copier après la connexion

Puis exécutez, php -m commande. 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.

Recommandations associées :

Introduction aux nouvelles fonctionnalités de PHP7

Méthodes de gestion des erreurs et des exceptions PHP7

Comment créer un environnement de test de performances pour php7


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!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal
À propos de nous Clause de non-responsabilité Sitemap
Site Web PHP chinois:Formation PHP en ligne sur le bien-être public,Aidez les apprenants PHP à grandir rapidement!