CXLIV. Sockets
Introduction
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.
Pour une interface socket cliente plus générique, voyez stream_socket_client(), stream_socket_server(), fsockopen() et pfsockopen().
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.
Pré-requis
Ces fonctions sont disponibles dans le module PHP standard, qui est toujours accessible.
Installation
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.
Configuration à l'exécution
Cette extension ne définit aucune directive de configuration.
Types de ressources
Cette extension ne définit aucune ressource.
Constantes pré-définies
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.
- AF_UNIX (entier)
- AF_INET (entier)
- AF_INET6 (entier)
- SOCK_STREAM (entier)
- SOCK_DGRAM (entier)
- SOCK_RAW (entier)
- SOCK_SEQPACKET (entier)
- SOCK_RDM (entier)
- MSG_OOB (entier)
- MSG_WAITALL (entier)
- MSG_PEEK (entier)
- MSG_DONTROUTE (entier)
- SO_DEBUG (entier)
- SO_REUSEADDR (entier)
- SO_KEEPALIVE (entier)
- SO_DONTROUTE (entier)
- SO_LINGER (entier)
- SO_BROADCAST (entier)
- SO_OOBINLINE (entier)
- SO_SNDBUF (entier)
- SO_RCVBUF (entier)
- SO_SNDLOWAT (entier)
- SO_RCVLOWAT (entier)
- SO_SNDTIMEO (entier)
- SO_RCVTIMEO (entier)
- SO_TYPE (entier)
- SO_ERROR (entier)
- SOL_SOCKET (entier)
- PHP_NORMAL_READ (entier)
- PHP_BINARY_READ (entier)
- SOL_TCP (entier)
- SOL_UDP (entier)
Erreurs de socket
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
Exemples
Exemple 2. Exemple avec les sockets : client TCP/IP simple Cet exemple implémente un client HTTP simple. Il se connecte simplement à une page, envoie une requête HEAD, affiche le résultat et se termine.
|
- Table des matières
- socket_accept -- Accepte une connexion sur une socket
- socket_bind -- Lie un nom à une socket
- socket_clear_error -- Efface toutes les erreurs précédemment générées par une socket
- socket_close -- Ferme une socket
- socket_connect -- Crée une connexion sur une socket
- socket_create_listen -- Ouvre une socket sur un port pour accepter les connexions
- socket_create_pair -- Crée une paire de sockets identiques et les stocke dans un tableau
- socket_create -- Crée une socket
- socket_get_option -- Lit les options de la socket
- socket_getpeername -- Interroge l'autre extrémité de la communication
- socket_getsockname -- Interroge la socket locale
- socket_last_error -- Lit la dernière erreur générée par une socket
- socket_listen -- Attend une connexion sur une socket
- socket_read -- Lit des données d'une socket
- socket_recv -- Reçoit des données d'une socket connectée
- socket_recvfrom -- Reçoit des données d'une socket, connectée ou pas
- socket_select -- Exécute l'appel système select() un tableau de sockets avec une durée d'expiration
- socket_send -- Envoie des données à une socket connectée
- socket_sendto -- Envoie une message à une socket, qu'elle soit connectée ou pas
- socket_set_block -- Met la socket en mode bloquant
- socket_set_nonblock -- Sélectionne le mode non bloquant d'un descripteur de fichier
- socket_set_option -- Modifie les options de socket
- socket_shutdown -- Eteint une socket en lecture et/ou écriture
- socket_strerror -- Retourne une chaîne décrivant un message d'erreur
- socket_write -- Ecrit dans une socket
Outils (masquer)
S'enregistrer
Liste des Membres
Qui est en ligne?
FAQ