Se connecter
Se connecter
Inscription
Mot de passe perdu
Connexion:
[Actualités]
OpenAI abandonne la fonctionnalité controversée de publicités sur ChatGPT
[Actualités]
Scandale au sein de la police britannique : le ministère dissimule les failles ...
[Actualités]
Paramount lance une offre publique d'achat hostile sur Warner Bros. Discovery
[Actualités]
TikTok lance Nearby Feed : le nouveau flux qui nous montre ce qui se passe rée...
[Actualités]
Astral est l'application Google Agenda native pour Windows et elle est entièrem...
[Actualités]
Test Mamorukun ReCurse ! (PS5) - Un shoot'em up old school ressort du placard
[Actualités]
WhatsApp se dote d'un nouveau panneau de confidentialité, mais Meta AI l'ignore.
[Actualités]
Les widgets arrivent sur l'écran de verrouillage d'Android, mais peut-être aur...
[Actualités]
Windows 11 25H2 arrive également pour les utilisateurs de Windows 10, mais atte...
[Actualités]
Microsoft a dissimulé une faille de sécurité de Windows pendant 8 ans. Ils pr...
[Articles]
Mamorukun ReCurse !
[Articles]
Fool Night tome 10
[Articles]
Morsels
[Articles]
Bus World
[Articles]
Trillion Game tome 10
[Articles]
Sonic Wings Reunion
[Articles]
Eclipse humaine tome 5
[Articles]
Plus de la moitié des informaticiens belges subissent une charge de travail sup...
[Articles]
L’iranien MuddyWater se fait passer pour Snake et vise des infrastructures en ...
[Articles]
Les nouvelles aventures de Barbe-Rouge tome 5 : L'Île aux Chimères
Actualités
Lettre d'information
Proposer une actualité
Archives
Actualités
Articles
Programmation
Press Release
Matériel
Logiciels
Livres
Interviews
Derniers commentaires
Jeux Vidéos
XBox One
XBox 360
Wii U
PSP
PS4
PS3
PC
DS
GameCube
3DS
Forum
Derniers messages
Informatique
Fun
Divers
Logithèque
Blogs
Divers
A Propos
Annonceurs
Contact
Recherche
RSS
Editer un article
Titre
Mots Clés
Texte
[size=18] [b]Nom[/b] [/size] gethostbyname, gethostbyaddr, sethostent, endhostent, herror, hstrerror - Obtenir des informations concernant le réseau. [size=18] [b]Résumé[/b] [/size] .nf [b]#include
[/b] [b]extern int h_errno;[/b] [b][i]struct hostent *gethostbyname(const char * name );[/i][/b] [b]#include
/* pour avoir AF_INET */[/b] [b][i]struct hostent *gethostbyaddr(const char * addr ,[/i][/b] [b][i] int len , int type );[/i][/b] [b][i]void sethostent(int stayopen );[/i][/b] [b]void endhostent(void);[/b] [b][i]void herror(const char * s );[/i][/b] [b][i]const char * hstrerror(int err );[/i][/b] 2 /* extensions GNU */ [b][/b] [b][i]struct hostent *gethostbyname2(const char * name , int af );[/i][/b] [b][i]int gethostbyname_r (const char * name ,[/i][/b] [b][i] struct hostent * ret , char * buf , size_t buflen ,[/i][/b] [b][i] struct hostent ** result , int * h_errnop );[/i][/b] [b][i]int gethostbyname2_r (const char * name , int af,[/i][/b] [b][i] struct hostent * ret , char * buf , size_t buflen ,[/i][/b] [b][i] struct hostent ** result , int * h_errnop );[/i][/b] .fi [size=18] [b]Description[/b] [/size] La fonction [b]gethostbyname()[/b] renvoie une structure de type [i]hostent[/i] pour l'hôte [i]name[/i]. La chaîne [i]name[/i] est soit un nom d'hôte, soit une adresse IPv4 en notation pointée standard, soit une adresse IPv6 avec la notation points-virgules et points (Cf RFC 1884 pour la description des adresses IPv6). Si [i]name[/i] est une adresse IPv4 ou IPv6, aucune recherche supplémentaire n'a lieu et [b]gethostbyname ()[/b] copie simplement la chaine [i]name[/i] dans le champ [i]h_name[/i] et le champs équivalent [i]struct in_addr[/i] dans le champs [i]h_addr_list[0][/i] de la structure [i]hostent[/i] renvoyée. Si [i]name[/i] ne se termine pas par un point, et si la variable d'environnement [b]HOSTALIASES[/b] est configurée, le fichier d'alias indiqué par [b]HOSTALIASES[/b] sera d'abord parcouru à la recherche de [i]name[/i] (voir [b]hostname (7)[/b] pour le format du fichier). Le domaine courant et ses parents sont parcourus si [i]name[/i] ne se termine pas par un point. La fonction [b]gethostbyaddr()[/b] renvoie une structure du type [i]hostent[/i] pour l'hôte d'adresse [i]addr[/i]. Cette adresse est de longueur [i]len[/i] et du [i]type[/i] donné. Le seul type d'adresse valide est actuellement [b]AF_INET .[/b] La fonction [b]sethostent()[/b] indique, si [i]stayopen[/i] est vrai (vaut 1), qu'une socket TCP connectée doit être utilisée 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 [b]endhostent()[/b] ferme la socket TCP connectée utilisée pour interroger le serveur de noms du domaine. La fonction (obsolète) [b]herror()[/b] affiche le message d'erreur associé avec la valeur courante de [i]h_errno[/i] sur la sortie standard stderr. La fonction (obsolète) [b]herror()[/b] reçoit un numéro d'erreur en argument (typiquement [i]h_errno[/i]) et renvoit la chaîne de message d'erreur. Les interrogations du serveur de noms effectuées par [b]gethostbyname()[/b] et [b]gethostbyaddr()[/b] utilisent les éléments suivants : le serveur de noms [b]named[/b](8), les lignes de [i]/etc/hosts[/i], et l'annuaire Network Information Service (NIS ou YP), suivant le contenu de la ligne [i]order[/i] du fichier [i]/etc/host.conf[/i]. (Voir [b]resolv+ (8)).[/b] L'action par défaut consiste à interroger [b]named[/b](8), puis [i]/etc/hosts[/i]. La structure [i]hostent[/i] est définie ainsi dans [i]
[/i] : [table][row][col] [/col][col] .nf .ne 7 .ta 8n 16n 32n 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] /* pour compatibilité. */ .ta .fi[/col][/row][/table] Les membres de la structure [i]hostent[/i] sont : [i]h_name[/i] [table][row][col] [/col][col]Nom officiel de l'hôte.[/col][/row][/table] [i]h_aliases[/i] [table][row][col] [/col][col]Une table, terminée par zéro, d'alternatives au nom officiel de l'hôte.[/col][/row][/table] [i]h_addrtype[/i] [table][row][col] [/col][col]Le type d'adresse (actuellement, toujours [b]AF_INET ).[/b] [/col][/row][/table] [i]h_length[/i] [table][row][col] [/col][col]La longueur, en octets, de l'adresse.[/col][/row][/table] [i]h_addr_list[/i] [table][row][col] [/col][col]Une table, terminée par zéro, d'adresses réseau pour l'hôte, avec l'ordre des octets du réseau.[/col][/row][/table] [i]h_addr[/i] [table][row][col] [/col][col]La première adresse dans [i]h_addr_list[/i] pour respecter la compatibilite ascendante.[/col][/row][/table] [size=18] [b]Valeur renvoyée[/b] [/size] Les fonctions [b]gethostbyname()[/b] et [b]gethostbyaddr()[/b] renvoient un pointeur sur la structure [i]hostent[/i], ou bien un pointeur NULL si une erreur se produit, auquel cas [i]h_errno[/i] contient le code d'erreur. [size=18] [b]Erreurs[/b] [/size] La variable [i]h_errno[/i] peut prendre les valeurs suivantes : [b]HOST_NOT_FOUND[/b] [table][row][col] [/col][col]L'hôte indiqué est inconnu.[/col][/row][/table] [b]NO_ADDRESS ou NO_DATA [/b] [table][row][col] [/col][col]Le nom est valide mais ne possède pas d'adresse IP.[/col][/row][/table] [b]NO_RECOVERY[/b] [table][row][col] [/col][col]Une erreur fatale du serveur de noms est apparue.[/col][/row][/table] [b]TRY_AGAIN[/b] [table][row][col] [/col][col]Une erreur temporaire du serveur de noms est apparue, essayez un peu plus tard.[/col][/row][/table] [size=18] [b]Fichiers[/b] [/size] [i]/etc/host.conf[/i] [table][row][col] [/col][col]Fichier de configuration de la résolution de noms.[/col][/row][/table] [i]/etc/hosts[/i] [table][row][col] [/col][col]Base de données des hôtes.[/col][/row][/table] [size=18] [b]Conformité[/b] [/size] BSD 4.3 [size=18] [b]Notes[/b] [/size] Les spécifications SUS-v2 déclarent - à tort - le paramètre [i]len[/i] de [b]gethostbyaddr()[/b] de type [b]size_t .[/b] (Ceci est erroné car il doit obligatoirement être un [b]int ,[/b] ce que [i]size_t[/i] n'est pas toujours. POSIX 1003.1-2001 le déclare [b]socklen_t ,[/b] ce qui est correct). Les fonctions [b]gethostbyname () [/b] et [b]gethostbyaddr () [/b] peuvent renvoyer des pointeurs sur des données statiques susceptibles d'être écrasées d'un appel à l'autre. Copier la structure [i]struct hostent[/i] ne suffit pas car elle contient elle-même des pointeurs. Une copie en profondeur est indispensable. La GlibC 2 propose aussi une fonction [b]gethostbyname2()[/b] qui agit comme [b]gethostbyname() ,[/b] qui permet de préciser la famille à laquelle l'adresse doit appartenir. La GlibC 2 propose aussi les versions réentrantes [b]gethostbyname_r()[/b] et [b]gethostbyname2_r() .[/b] Elles renvoient zéro si elles réussissent et une valeur non-nulle en cas d'erreur. Le résultat de l'appel est stocké dans la structure d'adresse [b]ret .[/b] Après l'appel, [i]* result[/i] vaudra NULL en cas d'erreur, ou pointera sur le résultat. Des données auxiliaires seront stockées dans le buffer [i]buf[/i] de longueur [b]buflen .[/b] (Si le buffer est trop petit, ces fonctions renverront [b]ERANGE ).[/b] La variable [i]h_errno[/i] n'est pas modifiée, mais l'adresse d'une variable où stocker le code d'erreur est transmis dans [b]h_errnop .[/b] POSIX 1003.1-2001 indique [b]gethostbyaddr()[/b] et [b]gethostbyname()[/b] comme légaux, et introduit .nf [b][i]struct hostent * getipnodebyaddr (const void * restrict addr ,[/i][/b] [b][i] socklen_t len , int type , int * restrict error_num );[/i][/b] [b][i]struct hostent *getipnodebyname (const char * name ,[/i][/b] [b][i] int type , int flags , int * error_num );[/i][/b] [size=18] [b]Voir aussi[/b] [/size] [b]resolver (3),[/b] [b]hosts (5), [/b] [b]hostname (7),[/b] [b]resolv+ (8),[/b] [b]named (8).[/b] [size=18] [b]Traduction[/b] [/size] Christophe Blaess, 1996-2003.
Fichier
Forum
-
Derniers messages
Bavardages
Aujourd'hui, je rénove ou je construis ^^
Informations
Besoin d’avis sur l’UX de mon mini-projet web (et plus globalement sur ce qui vous rebute sur un site) ?
Software
problème sur windows 10
Réseaux et Télécom
Problème wifi (POE)
Software
Postfix - Need help
Bavardages
Oh râge oh désespoir !
Programmation
Enregistrement client et envoi mail
Software
SÉCURITÉ MACBOOK
Hardware
conseil matos réseau?
Hardware
nVidia Shield Android TV
Actualités
-
Archives
Programmation
OpenAI abandonne la fonctionnalité controversée de publicités sur ChatGPT
Droit
Scandale au sein de la police britannique : le ministère dissimule les failles de la reconnaissance faciale par IA
Vidéo
Paramount lance une offre publique d'achat hostile sur Warner Bros. Discovery
Social
TikTok lance Nearby Feed : le nouveau flux qui nous montre ce qui se passe réellement autour de nous.
Google
Astral est l'application Google Agenda native pour Windows et elle est entièrement gratuite.
Ada
CSS
Cobol
CPP
HTML
Fortran
Java
JavaScript
Pascal
Perl
PHP
Python
SQL
VB
XML
Anon URL
DailyMotion
eBay
Flickr
FLV
Google Video
Google Maps
Metacafe
MP3
SeeqPod
Veoh
Yahoo Video
YouTube
6px
8px
10px
12px
14px
16px
18px
Informaticien.be
- © 2002-2025
Akretio
SPRL - Generated via
Kelare
The Akretio Network:
Akretio
-
Freedelity
-
KelCommerce
-
Votre publicité sur informaticien.be ?