Man page - endhostent(3)

Packages contains this manual

Available languages:

en fr pl ja ru de

Manual

gethostbyname

NOM
BIBLIOTHÈQUE
SYNOPSIS
DESCRIPTION
Historique
VALEUR RENVOYÉE
ERREURS
FICHIERS
ATTRIBUTS
STANDARDS
HISTORIQUE
NOTES
Extension System V/POSIX
Extensions GNU
BOGUES
VOIR AUSSI
TRADUCTION

NOM

gethostbyname, gethostbyaddr, sethostent, gethostent, endhostent, h_errno, herror, hstrerror, gethostbyaddr_r, gethostbyname2, gethostbyname2_r, gethostbyname_r, gethostent_r - Obtenir des informations concernant le réseau

BIBLIOTHÈQUE

BibliothĂšque C standard ( libc , -lc )

SYNOPSIS

#include <netdb.h>

void sethostent(int stayopen );
void endhostent(void);

[[obsolĂšte]] extern int h_errno;

[[obsolĂšte]] struct hostent *gethostbyname(const char * name );
[[obsolĂšte]] struct hostent *gethostbyaddr(const void
addr [. len ],
socklen_t
len , int type );

[[obsolĂšte]] void herror(const char * s );
[[obsolĂšte]] const char *hstrerror(int
err );

/* Extension System V/POSIX */
struct hostent *gethostent(void);

/* Extensions GNU */
[[obsolĂšte]]
struct hostent *gethostbyname2(const char *
name , int af );

int gethostent_r(struct hostent *restrict ret ,
char
buf [restrict . buflen ], size_t buflen ,
struct hostent **restrict
result ,
int *restrict
h_errnop );

[[obsolĂšte]]
int gethostbyaddr_r(const void
addr [restrict . len ], socklen_t len ,
int
type ,
struct hostent *restrict
ret ,
char
buf [restrict . buflen ], size_t buflen ,
struct hostent **restrict
result ,
int *restrict
h_errnop );
[[obsolĂšte]]
int gethostbyname_r(const char *restrict
name ,
struct hostent *restrict
ret ,
char
buf [restrict . buflen ], size_t buflen ,
struct hostent **restrict
result ,
int *restrict
h_errnop );
[[obsolĂšte]]
int gethostbyname2_r(const char *restrict
name , int af,
struct hostent *restrict
ret ,
char
buf [restrict . buflen ], size_t buflen ,
struct hostent **restrict
result ,
int *restrict
h_errnop );

Exigences de macros de test de fonctionnalités pour la glibc (consulter feature_test_macros (7)) :

gethostbyname2 (), gethostent_r (), gethostbyaddr_r (), gethostbyname_r (), gethostbyname2_r () :
Depuis la glibc 2.19 :
_DEFAULT_SOURCE
glibc <= 2.19:
_BSD_SOURCE || _SVID_SOURCE

herror (), hstrerror () :
Depuis la glibc 2.19 :
_DEFAULT_SOURCE
De la glibc 2.8 Ă  la glibc 2.19 :
_BSD_SOURCE || _SVID_SOURCE
Avant la glibc 2.8 :
aucun

h_errno :
Depuis la glibc 2.19 :
_DEFAULT_SOURCE || _POSIX_C_SOURCE < 200809L
De la glibc 2.12 Ă  la glibc 2.19 :
_BSD_SOURCE || _SVID_SOURCE || _POSIX_C_SOURCE < 200809L
Avant la glibc 2.12 :
aucun

DESCRIPTION

gethostbyname* (), gethostbyaddr* (), herror () et hstrerror () sont déconseillées. Les applications devraient utiliser getaddrinfo (3), getnameinfo (3) et gai_strerror (3) à la place.

La fonction sethostent () indique, si stayopen est vrai (vaut 1), qu’un socket TCP connectĂ© doit ĂȘtre utilisĂ© pour interroger le serveur de noms et que la connexion doit rester ouverte durant les demandes successives. Sinon l’interrogation utilisera des datagrammes UDP.

La fonction endhostent () ferme le socket TCP connecté utilisé pour interroger le serveur de noms.

La fonction gethostbyname () renvoie une structure de type hostent pour l’hĂŽte name . La chaĂźne name est soit un nom d’hĂŽte, soit une adresse IPv4 en notation pointĂ©e standard (comme pour inet_addr (3)). Si name est une adresse IPv4, aucune recherche supplĂ©mentaire n’a lieu et gethostbyname () copie simplement la chaĂźne name dans le champ h_name et le champ Ă©quivalent struct in_addr dans le champ h_addr_list[0] de la structure hostent renvoyĂ©e. Si name ne se termine pas par un point et si la variable d’environnement HOSTALIASES est configurĂ©e, le fichier d’alias pointĂ© par HOSTALIASES sera d’abord parcouru Ă  la recherche de name (consultez hostname (7) pour le format du fichier). Le domaine courant et ses parents sont parcourus Ă  moins que name se termine par un point.

La fonction gethostbyaddr () renvoie une structure du type hostent pour l’hĂŽte d’adresse addr . Cette adresse est de longueur len et du type type . Les types d’adresse valables sont AF_INET et AF_INET6 (dĂ©finis dans <sys/socket.h> ). L’argument adresse de l’hĂŽte est un pointeur vers une structure de type dĂ©pendant du type de l’adresse, par exemple struct in_addr * (probablement obtenu Ă  l’aide d’un appel Ă  inet_addr (3)) pour une adresse de type AF_INET .

La fonction (obsolĂšte) herror () affiche le message d’erreur associĂ© avec la valeur courante de h_errno sur la sortie standard stderr .

La fonction (obsolĂšte) hstrerror () reçoit un numĂ©ro d’erreur en argument (typiquement h_errno ) et renvoie la chaĂźne de message d’erreur.

Les recherches de noms de domaine effectuĂ©es par gethostbyname () et gethostbyaddr () dĂ©pendent des sources configurĂ©es de service de noms (Name Service Switch — nsswitch.conf (5)) ou d’un serveur de noms local ( named (8)). L’action par dĂ©faut est de chercher dans les sources du service de noms configurĂ© ( nsswitch.conf (5), et en cas d’échec, dans un serveur de noms local ( named (8)).

Historique

Le fichier nsswitch.conf (5) est un moyen moderne pour contrîler l’ordre des recherches d’hîte.

Dans la glibc 2.4 et antĂ©rieure, le mot clĂ© order Ă©tait utilisĂ© pour contrĂŽler l’ordre des recherches d’hĂŽte comme il est dĂ©fini dans /etc/host.conf ( host.conf (5)).

La structure hostent est définie ainsi dans <netdb.h> :

struct hostent {
char *h_name; /* Nom officiel de l’hîte */
char **h_aliases; /* Liste d’alias */
int h_addrtype; /* Type d’adresse de l’hîte */
int h_length; /* Longueur de l’adresse */
char **h_addr_list; /* Liste d’adresses */
}
#define h_addr h_addr_list[0] /* for backward compatibility */

Les membres de la structure hostent sont :

h_name

Nom officiel de l’hîte.

h_aliases

Un tableau, terminĂ© par un pointeur NULL, d’alternatives au nom officiel de l’hĂŽte.

h_addrtype

Le type d’adresse : actuellement toujours AF_INET ou AF_INET6 .

h_length

La longueur, en octets, de l’adresse.

h_addr_list

Un tableau, terminĂ© par un pointeur NULL, d’adresses rĂ©seau pour l’hĂŽte, avec l’ordre des octets du rĂ©seau.

h_addr

La premiÚre adresse dans h_addr_list pour respecter la compatibilité ascendante.

VALEUR RENVOYÉE

Les fonctions gethostbyname () et gethostbyaddr () renvoient un pointeur vers la structure hostent , ou un pointeur NULL si une erreur se produit, auquel cas h_errno contient le code d’erreur. Lorsqu’elle n’est pas NULL, la valeur de retour peut pointer sur une donnĂ©e statique. Consultez les notes plus loin.

ERREURS

La variable h_errno peut prendre les valeurs suivantes :
HOST_NOT_FOUND

L’hĂŽte indiquĂ© est inconnu.

NO_DATA

Le nom de la requĂȘte est valable, mais ne possĂšde pas d’adresse IP. Un autre type de requĂȘte au serveur de noms pour ce domaine peut renvoyer une rĂ©ponse. La constante NO_ADDRESS est un synonyme de NO_DATA .

NO_RECOVERY

Une erreur fatale du serveur de noms est survenue.

TRY_AGAIN

Une erreur temporaire d’un serveur de noms faisant autoritĂ© est survenue, essayez un peu plus tard.

FICHIERS

/etc/host.conf

fichier de configuration de resolver (résolution de noms)

/etc/hosts

Base de données des hÎtes.

/etc/nsswitch.conf

Configuration du service de noms.

ATTRIBUTS

Pour une explication des termes utilisés dans cette section, consulter attributes (7).

Image grohtml-3885183-1.png

Dans la table ci-dessus, hostent dans race:hostent signifie que si une des fonctions sethostent (), gethostent (), gethostent_r () ou endhostent () est utilisĂ©e en parallĂšle dans diffĂ©rents threads d’un programme, des situations de concurrence de donnĂ©es peuvent se produire.

STANDARDS

sethostent ()
endhostent
()
gethostent
()

POSIX.1-2008.

gethostent_r ()

GNU.

Autres :

Aucune

HISTORIQUE

sethostent ()
endhostent
()
gethostent
()

POSIX.1-2001.

gethostbyname ()
gethostbyaddr
()
h_errno

MarquĂ©e comme obsolĂšte dans POSIX.1-2001. RetirĂ©e dans POSIX.1-2008 qui recommande l’utilisation de getaddrinfo (3) et getnameinfo (3) Ă  la place.

NOTES

Les fonctions gethostbyname () et gethostbyaddr () peuvent renvoyer des pointeurs sur des donnĂ©es statiques susceptibles d’ĂȘtre Ă©crasĂ©es d’un appel Ă  l’autre. Copier la structure struct hostent ne suffit pas car elle contient elle-mĂȘme des pointeurs. Une copie en profondeur est indispensable.

Dans l’implĂ©mentation BSD originale, l’argument len de gethostbyname () Ă©tait un int . Les spĂ©cifications SUS-v2 sont dĂ©fectueuses et dĂ©clarent le paramĂštre len de gethostbyaddr () comme Ă©tant de type size_t (c’est erronĂ© car il doit obligatoirement ĂȘtre un int , ce que size_t n’est pas toujours. POSIX.1-2001 le dĂ©clare socklen_t , ce qui est correct). Consultez Ă©galement accept (2).

Le prototype BSD pour gethostbyaddr () utilise const char * comme premier argument.

Extension System V/POSIX

POSIX rĂ©clame l’appel gethostent (), qui devrait renvoyer la prochaine entrĂ©e de la base de donnĂ©es des hĂŽtes. Avec DNS/BIND, cela n’a pas plus de sens, mais cela peut ĂȘtre raisonnable si la base de donnĂ©es des hĂŽtes est un fichier qui peut ĂȘtre lu ligne par ligne. Sur beaucoup de systĂšmes, une routine de ce nom lit le fichier /etc/hosts . Elle n’est disponible que lorsque la bibliothĂšque est construite sans la gestion DNS. L’équivalent de la glibc ignore les entrĂ©es IPv6. Cette fonction n’est pas rĂ©entrante, mais la glibc propose une version rĂ©entrante, gethostent_r ().

Extensions GNU

La glibc2 propose aussi une fonction gethostbyname2 () qui agit comme gethostbyname (), qui permet de prĂ©ciser la famille Ă  laquelle l’adresse doit appartenir.

La glibc2 propose aussi les versions rĂ©entrantes gethostent_r (), gethostbyaddr_r (), gethostbyname_r () et gethostbyname2_r (). L’appelant fournit une structure hostent Ă  l’aide de ret qui sera remplie en cas de succĂšs et un tampon de travail temporaire buf de taille buflen . AprĂšs l’appel, result pointera vers le rĂ©sultat en cas de succĂšs. En cas d’erreur ou si aucune entrĂ©e n’a Ă©tĂ© trouvĂ©e, result vaudra NULL Les fonctions renvoient 0 en cas de succĂšs et une valeur non nulle en cas d’erreur. En plus des erreurs renvoyĂ©es par ces fonctions rĂ©entrantes, si buf est trop petit, les fonctions renvoient ERANGE et l’appel devra ĂȘtre effectuĂ© par la suite avec un tampon plus grand. La variable h_errno n’est pas modifiĂ©e, mais l’adresse d’une variable oĂč est stockĂ© le code d’erreur est transmise dans h_errnop .

BOGUES

gethostbyname () ne reconnaĂźt pas les Ă©lĂ©ments d’une adresse IPv4 en notation pointĂ©e si ces Ă©lĂ©ments sont exprimĂ©s en hexadĂ©cimal.

VOIR AUSSI

getaddrinfo (3), getnameinfo (3), inet (3), inet_ntop (3), inet_pton (3), resolver (3), hosts (5), nsswitch.conf (5), hostname (7), named (8)

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@laposte.net>, Thierry Vignaud <tvignaud@mandriva.com>, François Micaux, Alain Portal <aportal@univ-montp2.fr>, Jean-Philippe Guérard <fevrier@tigreraye.org>, Jean-Luc Coulon (f5ibh) <jean-luc.coulon@wanadoo.fr>, Julien Cristau <jcristau@debian.org>, Thomas Huriaux <thomas.huriaux@gmail.com>, Nicolas François <nicolas.francois@centraliens.net>, Florentin Duneau <fduneau@gmail.com>, Simon Paillard <simon.paillard@resel.enst-bretagne.fr>, Denis Barbier <barbier@debian.org>, David Prévot <david@tilapin.org> et Jean-Pierre Giraud <jean-pierregiraud@neuf.fr>

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@lists.debian.org .