L'extension socket implémente une interface bas niveau avec les fonctions
de communication par socket, basées sur les sockets BSD si populaires,
et fournit la possibilité de fonctionner aussi bien sous forme de client
que de serveur.
Lorsque vous utilisez ces fonctions, il est important de vous
rappeler que si de nombreuses fonctions ont le même nom que leur
équivalent en langage C, elles ont souvent des déclarations différentes.
Lisez attentivement les descriptions pour éviter des confusions.
Cela dit, ceux qui ne sont pas familiers avec la programmation par socket
peuvent toujours trouver beaucoup de documentation dans les pages de
manuel Unix appropriées, et il y a une grande quantité d'introductions
en langage C sur le web, qui peuvent être facilement réutilisées, avec
des adaptations mineures.
UNIX Socket FAQ est un bon début.
Les fonctions de socket décrites ici font partie d'une extension
PHP qui doit être activée lors de la compilation en
utilisant l'option --enable-sockets,
avec la commande configure.
Note : Le support des adresses IPv6 a été ajouté en
PHP 5.0.
Ces constantes sont définies par cette
extension, et ne sont disponibles que si cette extension a été compilée avec
PHP, ou bien chargée au moment de l'exécution.
L'extension socket a été écrite pour fournir une interface utilisable
avec les puissantes sockets fournies par BSD. Un soin particulier a été
apporté pour que les fonctions soient aussi efficaces sous Unix que sous
Windows. Presque toutes les fonctions de sockets peuvent échouer
dans certaines circonstances, et émettent ainsi un message d'alerte
E_WARNING décrivant l'erreur. Parfois, cela ne
se fait pas selon les souhaits du développeur. Par exemple, la fonction
socket_read() peut tout à coup émettre un
message E_WARNING car la connexion a été
inopinément interrompue. Il est commun de supprimer les erreurs avec
l'opérateur @ et de traiter les erreurs avec la
fonction socket_last_error(), au niveau de l'application.
Vous pouvez appeler socket_strerror() avec le code
d'erreur pour connaître le message d'erreur, humainement lisible.
Reportez-vous à leur description pour plus de détails.
Note :
Les messages E_WARNING générés par l'extension
socket sont en anglais, mais ils s'afficheront en fonction
de la configuration locale (LC_MESSAGES):
Warning - socket_bind() unable to bind address [98]: Die Adresse wird bereits verwendet
Exemple 1. Exemple de socket : serveur TCP/IP simple
Cet exemple montre comment créer un serveur simple.
Changez les variables address et
port pour vous adapter à votre configuration,
et exécutez-le. Vous pourrez alors vous connecter au serveur
avec une commande comme ceci : telnet 192.168.1.53
10000 (en supposant que l'adresse et le port correspondent
à votre configuration). Tout ce que vous saisissez après cela sera
envoyé au serveur, et affiché en retour. Pour vous déconnecter,
tapez 'quit'.