Développer une Extension PHP 5
Développer une Extension PHP 5
À propos du livre
Développer une Extension PHP permet de se positionner à mi-chemin entre le cœur de PHP et les scripts utilisateurs, vous donnant accès à la fois à plus de possibilités et à des performances optimales.
Coder en C et découvrir les API Zend et PHP peut sembler effrayant au premier abord, mais, avec un peu de méthode et un bon guide, vous découvrirez vite les bases nécessaires au développement d’une première extension.
Ce livre présente les différents concepts entrant en jeu lors de la mise en place d’une Extension PHP, illustrant chacun d’entre eux de nombreux exemples de code visant à faciliter leur mise en pratique.
Le livre Développer une Extension PHP regroupe, en 500+ pages, des chapitres traitant des sujets suivants :
- Création d’une première extension : il s’agit du premier chapitre du livre, qui est reproduit intégralement dans l’aperçu disponible en téléchargement. J’y explique comment créer le squelette d’une première extension, quels fichiers sources sont requis, et quelles structures de données et déclarations sont nécessaires.
- Environnement de développement : ce chapitre montre comment compiler une version de PHP orientée développement d’extensions et quelles sont les informations qu’elle nous apporte. J’en ai profité pour présenter comment configurer Eclipse CDT pour obtenir un environnement de développement avec débogueur graphique.
- Développer une extension PHP sous Windows : ce chapitre fait suite au précédent, en expliquant comment mettre en place un environnement de développement avec Visual Studio, sous Windows, en allant de la compilation de PHP jusqu’au débogage en interface graphique.
- Écrire une fonction : les fonctions sont au cœur de PHP et de ses extensions. Nous verrons ici, entre autres, comment recevoir des paramètres et retourner une valeur. Ce sujet est abordé au travers de deux chapitres, le second intégrant des concepts supplémentaires, comme la réception de zval en paramètres, les fonctions attendant un nombre d’arguments variable, ou encore le type-hinting.
- zval : les variables de PHP : les variables de PHP sont représentées, en interne, par une structure nommée zval. Ce chapitre nous montrera comment en créer, les lire et les manipuler.
- Gestion de la mémoire : ce chapitre introduit le Zend Memory Manager, les fonctions d’allocation et de libération de mémoire, et présente comment travailler avec le TSRMLS.
- HashTable et tableaux : la structure HashTable est utilisée par PHP pour stocker un ensemble de données, comme un tableau. Elle est tellement importante pour PHP qu’elle est fréquemment utilisée en interne, et que de nombreuses fonctions permettent de la manipuler.
- Classes et objets : PHP 5 a apporté un véritable modèle objet. Ce sujet est couvert à travers deux chapitres :
- Le premier montre comment créer des classes exposant constantes, propriétés et méthodes, comment travailler avec de l’héritage ou des interfaces et comment stocker des données complexes.
- Le second explique comment travailler avec des espaces de noms et des traits, présente quelques interfaces communément manipulées et passe en revue les gestionnaires d’objets les plus utilisés.
- Erreurs et Exceptions : PHP propose deux mécanismes de remontée d’imprévus à l’utilisateur : les erreurs, et les exceptions. Nous verrons ici comment tirer parti de ces deux principes, mais aussi comment transformer des erreurs internes en exceptions.
- Configuration par fichier .ini : le fichier php.ini représente, pour PHP et pour ses extensions, le standard de configuration permettant aux utilisateurs d’influencer sur leur comportement. Ce chapitre présentera comment exploiter au mieux cette possibilité de paramétrage.
- Tests automatisés : vous n’envisageriez pas de développer une extension sans tests automatisés ? Moi non plus !
- Travailler avec des flux : ce chapitre montre comment utiliser le mécanisme de flux de PHP, en lecture et en écriture. Il enchaîne ensuite avec la mise en place d’un gestionnaire de flux, avant de passer à la notion de contexte de flux et au développement d’un filtre de flux.
- Les ressources : nous verrons ici ce qu’est le type ressource et comment déclarer et manipuler des ressources, qu’elles soient ou non persistantes.
- Configuration plus avancée de la compilation et du chargement de l’extension : ce chapitre vous présentera comment mettre en place des dépendances entre extensions, comment utiliser une bibliothèque partagée externe, ou encore comment compiler votre extension de manière statique, intégrée à PHP.
- Quelques points divers : ce chapitre regroupe quelques points intéressants, mais qui ne méritaient pas à un chapitre à eux seuls, comme la déclaration de variables super-globales, de constantes, la personnalisation de phpinfo(), ou encore l’exécution de code PHP et l’utilisation de fonctions de rappel depuis une extension. Ce chapitre est reproduit en grande partie dans l’aperçu disponible au téléchargement.
- Les Extensions Zend : ce chapitre, rédigé par Julien Pauli, montre de quelles possibilités dispose une extension Zend et comment en mettre en place -- ainsi qu’un exemple d’une extension qui soit à la fois une extension PHP traditionnelle et une extension Zend.
- Un œil dans la Zend Virtual Machine : ce chapitre, également rédigé par Julien Pauli, constitue une introduction au fonctionnement de la machine virtuelle de PHP et montre comment une extension ou une zend_extension peuvent jouer avec celui-ci.
La version publiée du livre sera bien sûr mise à jour, gratuitement, en cas d’éventuelles corrections.
À propos des contributeurs
Préfacier, Relecteur technique
Table des matières
- Préface
-
Introduction
- Pourquoi développer une extension PHP ?
- Pourquoi ne pas développer une extension PHP ?
- À qui s’adresse ce livre ?
- Remerciements
- À propos de l’auteur
-
1. Une toute première extension
- 1.1 Fichiers sources et configuration de la compilation
- 1.2 Compilation de l’extension
- 1.3 Et voila, une nouvelle extension !
- 1.4 Contrôle de sources et fichiers à ignorer
-
2. Environnement de développement
- 2.1 PHP en mode débug + ZTS
- 2.2 Compilation de PHP
- 2.3 Impacts pour la compilation et l’utilisation d’une extension
- 2.4 Mais qu’est-ce que ça nous apporte ?
- 2.5 Un environnement graphique avec débugger
-
3. Développer une extension PHP sous Windows
- 3.1 Microsoft Visual C++ et environnement de développement
- 3.2 Compilation de PHP
- 3.3 Une première extension PHP sous Windows
- 3.4 Exécution et débogueur graphique ?
-
4. Écrire une fonction – partie 1
- 4.1 Définir une fonction
- 4.2 Recevoir des paramètres
- 4.3 Retourner une valeur
-
5. Le cycle de vie de PHP
- 5.1 Module Init/Shutdown, Request Init/Shutdown
- 5.2 Des fonctionnements variables selon la SAPI
-
6. Zvals : les variables de PHP
- 6.1 Structure d’une zval
- 6.2 Lire une zval
- 6.3 Créer une zval et lire sa valeur
- 6.4 Conversions de types
- 6.5 Références et comptage de références
- 6.6 Copy on write ?
-
7. Gestion de la mémoire
- 7.1 Zend Memory Manager
- 7.2 Zend Thread Safety et TSRMLS
- 7.3 Variables globales à une extension
- 7.4 Quelques mots à propos de Valgrind
-
8. HashTables et tableaux
-
8.1
HashTable
: les opérations basiques -
8.2 Parcourir une
HashTable
- 8.3 Tris, comparaisons, copies et fusions
-
8.4 Manipulations “rapides” de
HashTable
- 8.5 Des HashTables partout !
- 8.6 HashTable et zval : les tableaux de PHP
-
8.1
-
9. Écrire une fonction – partie 2
-
9.1 Retourner une
zval
-
9.2 Recevoir une
zval
en paramètre - 9.3 Passage de paramètres par référence
- 9.4 Nombre variable d’arguments
-
9.5
ARG_INFO
et type-hinting : le retour ! - 9.6 Et aussi
-
9.1 Retourner une
-
10. Classes et Objets – partie 1
- 10.1 Déclarer une classe
- 10.2 Constantes de classes
- 10.3 Propriétés
- 10.4 Méthodes
- 10.5 Stockage de données internes à la classe
- 10.6 Attributs et méthodes statiques
- 10.7 Instancier une classe, retourner un objet
- 10.8 Méthodes abstraites et héritage
- 10.9 Interfaces
-
11. Erreurs et exceptions
- 11.1 Erreurs
- 11.2 Exceptions
- 11.3 Transformer des erreurs internes en exceptions
-
12. Classes et Objets – partie 2
- 12.1 Espaces de noms
- 12.2 Traits
- 12.3 Quelques interfaces intéressantes
- 12.4 Handlers d’objets (et méthodes magiques)
-
13. Configuration par fichier
.ini
-
13.1 Déclarer et lire une propriété
.ini
- 13.2 Niveaux d’accès
- 13.3 Événement de modification
-
13.4 Modifier une propriété
.ini
-
13.5 Propriétés
.ini
et variables globales de l’extension -
13.6 Afficher les propriétés
.ini
dansphpinfo()
-
13.1 Déclarer et lire une propriété
-
14. Tests automatisés
- 14.1 Pourquoi des tests automatisés ?
- 14.2 Principes de base
- 14.3 Quelques points plus avancés
- 14.4 Code coverage
- 14.5 Référence des sections
-
15. Travailler avec des flux
- 15.1 Accéder à un flux
- 15.2 Implémenter un gestionnaire de flux
- 15.3 Notion de contexte de flux
- 15.4 Filtres de flux
-
16. Les ressources
- 16.1 Travailler avec une ressource
- 16.2 Ressources persistantes
- 16.3 Ressource persistante ou non
-
17. Configuration plus avancée de la compilation et du chargement de l’extension
- 17.1 Une extension qui dépend d’une autre extension
- 17.2 Extension partagée, ou statique ?
- 17.3 Utiliser une bibliothèque externe
-
18. Quelques points divers
- 18.1 Déclarer des constantes
- 18.2 Variables super-globales
-
18.3 Personnaliser la sortie de
phpinfo()
- 18.4 Rappeler du code PHP
-
19. Les Extensions Zend
- 19.1 Introduction
- 19.2 Différences avec les extensions PHP
- 19.3 Premiers pas avec une extension Zend
- 19.4 Les hooks, ou points de branchement
- 19.5 Une extension Zend qui se charge aussi en tant qu’extension PHP
- 19.6 Les hooks spécifiques aux extensions Zend
-
20. Un œil dans la Zend Virtual Machine
- 20.1 Introduction
- 20.2 Analyseur lexical et syntaxique (Lexer & Parser)
- 20.3 Compilateur
- 20.4 Exécuteur
- 20.5 Et les extensions PHP là-dedans ?
- 20.6 Un petit exemple d’extension ?
- 20.7 Conclusion
-
Annexe : Normes de codage et bonnes pratiques PECL
-
CODING_STANDARDS
: les normes de codage de PHP - Quelques conseils et bonnes pratiques PECL
-
Aucun risque ! Satisfait ou remboursé !
Durant les 60 jours suivant l'achat, vous pouvez obtenir un remboursement à 100% de la part de Leanpub, en moins de deux clics. Nous traitons les remboursements manuellement, un délai de quelques jours est nécessaire. Voir nos conditions générales.
Gagnez $8 pour un achat de $10 et $16 pour un achat de $20
Nous payons 80% de royalties sur les achats de $7,99 ou plus et 80% de royalties moins une commission fixe de 50 centimes sur les achats entre $0,99 et $7,98. Vous gagnez $8 pour une vente de $10 et $16 pour une vente de $20. Donc, si nous vendons 5000 exemplaires non remboursés de votre livre à $20, vous gagnerez $80,000.
(Oui, certains auteurs ont déjà gagné bien plus que cela sur Leanpub.)
En fait, les auteurs ont gagnéplus de 13 millions de dollars en écrivant, publiant et vendant sur Leanpub.
En savoir plus sur l'écriture sur Leanpub
Mises à jour gratuit. Sans DRM.
Si vous achetez un livre Leanpub, vous obtenez des mises à jour gratuit tant que l'auteur met à jour le livre ! De nombreux auteurs utilisent Leanpub pour publier leurs livres en cours, lorsqu'ils les écrivent. Tous les lecteurs obtiennent les mises à jour gratuites, quel que soit le moment où ils ont acheté le livre ou combien ils ont payé (même s'ils étaient gratuits).
La plupart des livres Leanpub sont disponibles en format PDF (pour les ordinateurs) et EPUB (pour les téléphones, les tablettes, et les Kindles). Les formats inclus sont affichés dans le coin droit supérieur de cette page.
Finalement, les livres Leanpub n'ont pas de DRM, d'abord vous pouvez toujour les lire facilement sur n'importe quel appareil pris en charge.
En savoir plus sur les formats des livres ebook de Leanpub et où les lire