NOM
getpeername - Obtenir le nom d’un correspondant connecté sur une socket
SYNOPSIS
#include <sys/socket.h>
int getpeername(int sockfd, struct sockaddr *addr, socklen_t *addrlen);
DESCRIPTION
La fonction getpeername() renvoie l’adresse du correspondant connecté sur la socket sockfd, dans le tampon pointé par addr. Le paramètre addrlen doit être initialisé pour indiquer la taille de la zone pointée par addr. En retour, il contiendra la longueur effective (en octets) du nom retourné. Le nom est tronqué si le tampon est trop petit.
L’adresse renvoyée est tronquée si le tampon fourni est trop petit ; dans ce cas, addrlen renverra une valeur supérieure à celle fournie lors de l’appel.
VALEUR RENVOYÉE
En cas de succès, zéro est renvoyé. En cas d’erreur, -1 est renvoyé et errno reçoit une valeur adéquate.
ERREURS
EBADF |
sockfd n’est pas un descripteur de fichier valable. | ||
EFAULT |
Le paramètre addr pointe en dehors de l’espace d’adressage accessible. | ||
EINVAL |
addrlen n’est pas valable (négatif, par exemple). |
ENOBUFS
Les ressources système disponibles sont insuffisantes.
ENOTCONN
La socket n’est pas connectée.
ENOTSOCK
Le descripteur de fichier sockfd ne fait pas référence à un socket.
CONFORMITÉ
POSIX.1-2001, POSIX.1-2008, SVr4, 4.4BSD (getpeername() first appeared in 4.2BSD).
NOTES
Pour plus de détails sur le type socklen_t, voir accept(2).
Pour les sockets flux, une fois que connect(2) a été réalisé, chaque socket peut appeler getpeername() pour obtenir l’adresse de la socket correspondante. D’un autre côté, les sockets datagramme sont sans connexion. Appeler connect(2) sur une socket datagramme définit simplement l’adresse correspondante pour les datagrammes sortants envoyés avec write(2) ou recv(2). L’appelant de connect(2) peut utiliser getpeername() pour obtenir l’adresse correspondante qui est définie plus tôt pour la socket. Cependant, la socket correspondante ne connaît pas ces renseignements et appeler getpeername() sur la socket correspondante ne renverra aucun renseignement utile (sauf si un appel connect(2) est aussi exécuté sur la correspondante). Remarquez aussi que le destinataire d’un datagramme peut obtenir l’adresse de l’expéditeur en utilisant recvfrom(2).
VOIR AUSSI
accept(2), bind(2), getsockname(2), ip(7), socket(7), unix(7)
COLOPHON
Cette page fait partie de la publication 5.07 du projet man-pages Linux. Une description du projet et des instructions pour signaler des anomalies et la dernière version de cette page, peuvent être trouvées à l’adresse https://www.kernel.org/doc/man-pages/.
TRADUCTION
La traduction française de cette page de manuel a été créée par Christophe Blaess <https://www.blaess.fr/christophe/>, Stéphan Rafin <stephan.rafin [AT] laposte.net>, Thierry Vignaud <tvignaud [AT] mandriva.com>, François Micaux, Alain Portal <aportal [AT] univ-montp2.fr>, Jean-Philippe Guérard <fevrier [AT] tigreraye.org>, Jean-Luc Coulon (f5ibh) <jean-luc.coulon [AT] wanadoo.fr>, Julien Cristau <jcristau [AT] debian.org>, Thomas Huriaux <thomas.huriaux [AT] gmail.com>, Nicolas François <nicolas.francois [AT] centraliens.net>, Florentin Duneau <fduneau [AT] gmail.com>, Simon Paillard <simon.paillard [AT] resel.fr>, Denis Barbier <barbier [AT] debian.org> et David Prévot <david [AT] tilapin.org>
Cette traduction est une documentation libre ; veuillez vous reporter à la GNU General Public License version 3 concernant les conditions de copie et de distribution. Il n’y a aucune RESPONSABILITÉ LÉGALE.
Si vous découvrez un bogue dans la traduction de cette page de manuel, veuillez envoyer un message à <debian-l10n-french [AT] lists.org>.