Explication détaillée de la méthode d'implémentation de Hello Word pour le développement d'extensions PHP7

jacklove
Libérer: 2023-04-02 07:54:01
original
1608 Les gens l'ont consulté

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

Contenu de sortie :

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

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
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.

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, 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);
}
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 installer

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

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

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

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

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.

Articles qui pourraient vous intéresser :

Explication détaillée de la méthode basée sur les fonctions d'utilisation de la bibliothèque lib dans le développement d'extensions PHP

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!

É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