netdb.h - definitions for network database operations
#include <netdb.h>
The <netdb.h> header may define the in_port_t type and the in_addr_t type as described in <netinet/in.h> .
The <netdb.h> header shall define the hostent structure that includes at least the following members:
char *h_name Official name of the host. char **h_aliases A pointer to an array of pointers to alternative host names, terminated by a null pointer. int h_addrtype Address type. int h_length The length, in bytes, of the address. char **h_addr_list A pointer to an array of pointers to network addresses (in network byte order) for the host, terminated by a null pointer.
The <netdb.h> header shall define the netent structure that includes at least the following members:
char *n_name Official, fully-qualified (including the domain) name of the host. char **n_aliases A pointer to an array of pointers to alternative network names, terminated by a null pointer. int n_addrtype The address type of the network. uint32_t n_net The network number, in host byte order.
The uint32_t type shall be defined as described in <inttypes.h> .
The <netdb.h> header shall define the protoent structure that includes at least the following members:
char *p_name Official name of the protocol. char **p_aliases A pointer to an array of pointers to alternative protocol names, terminated by a null pointer. int p_proto The protocol number.
The <netdb.h> header shall define the servent structure that includes at least the following members:
char *s_name Official name of the service. char **s_aliases A pointer to an array of pointers to alternative service names, terminated by a null pointer. int s_port The port number at which the service resides, in network byte order. char *s_proto The name of the protocol to use when contacting the service.
The <netdb.h> header shall define the IPPORT_RESERVED macro with the value of the highest reserved Internet port number.
When the <netdb.h> header is included, h_errno shall be available as a modifiable lvalue of type int. It is unspecified whether h_errno is a macro or an identifier declared with external linkage.
The <netdb.h> header shall define the following macros for use as error values for gethostbyaddr() and gethostbyname():
HOST_NOT_FOUND NO_DATA NO_RECOVERY TRY_AGAIN
The <netdb.h> header shall define the addrinfo structure that includes at least the following members:
int ai_flags Input flags. int ai_family Address family of socket. int ai_socktype Socket type. int ai_protocol Protocol of socket. socklen_t ai_addrlen Length of socket address. struct sockaddr *ai_addr Socket address of socket. char *ai_canonname Canonical name of service location. struct addrinfo *ai_next Pointer to next in list.
The <netdb.h> header shall define the following macros that evaluate to bitwise-distinct integer constants for use in the flags field of the addrinfo structure:
Request for canonical name.
Return numeric host address as name.
Inhibit service name resolution.
Query for IPv4 addresses only when an IPv4 address is configured; query for IPv6 addresses only when an IPv6 address is configured.
The <netdb.h> header shall define the following macros that evaluate to bitwise-distinct integer constants for use in the flags argument to getnameinfo():
The numeric form of the node's address is returned instead of its name.
The numeric form of the service address is returned instead of its name.
For IPv6 addresses, the numeric form of the scope identifier is returned instead of its name.
The <netdb.h> header shall define the following macros for use as error values for getaddrinfo() and getnameinfo():
NI_NAMEREQD is set and the host's name cannot be located, or both nodename and servname were null.
An argument buffer overflowed.
The following shall be declared as functions and may also be defined as macros. Function prototypes shall be provided.
void endhostent(void); void endnetent(void); void endprotoent(void); void endservent(void); void freeaddrinfo(struct addrinfo *); const char *gai_strerror(int); int getaddrinfo(const char *restrict, const char *restrict, const struct addrinfo *restrict, struct addrinfo **restrict); struct hostent *gethostbyaddr(const void *, socklen_t, int); struct hostent *gethostbyname(const char *); struct hostent *gethostent(void); int getnameinfo(const struct sockaddr *restrict, socklen_t, char *restrict, socklen_t, char *restrict, socklen_t, int); struct netent *getnetbyaddr(uint32_t, int); struct netent *getnetbyname(const char *); struct netent *getnetent(void); struct protoent *getprotobyname(const char *); struct protoent *getprotobynumber(int); struct protoent *getprotoent(void); struct servent *getservbyname(const char *, const char *); struct servent *getservbyport(int, const char *); struct servent *getservent(void); void sethostent(int); void setnetent(int); void setprotoent(int); void setservent(int);
The type socklen_t shall be defined through typedef as described in <sys/socket.h>.
Inclusion of the <netdb.h> header may also make visible all symbols from <netinet/in.h>, <sys/socket.h>, and <inttypes.h>.
The following sections are informative.
<netinet/in.h> , <inttypes.h> , <sys/socket.h> , the System Interfaces volume of IEEE Std 1003.1-2001, bind(), endhostent(), endnetent(), endprotoent(), endservent(), getaddrinfo(), getnameinfo()
Закладки на сайте Проследить за страницей |
Created 1996-2024 by Maxim Chirkov Добавить, Поддержать, Вебмастеру |