htons、ntohs、htonl和ntohl函数
Linux提供了4个函数来完成主机字节序和网络字节序之间的转换
#include <netinet/in.h>
uint16_t htons(uint16_t host16bitvalue);
uint32_t htonl(uint32_t host32bitvalue);
uint16_t ntohs(uint16_t net16bitvalue);
uint32_t ntohl(uint32_t net32bitvalue);
inet_aton、inet_addr和inet_ntoa函数
#include <arpa/inet.h>
int inet_aton(const char *strptr, struct in_addr *addrptr);
返回:若字符有效则为1,否则为0
in_addr_t inet_addr(const char *strptr);
返回:若字符串有效则为32位二进制网络字节序地址,否则为INADDR_NONE
char *inet_ntoa(struct in_addr inaddr);
返回:指向一个点分十进制数串的地址
inet_aton将strptr所指向的字符串转换为32网络字节序二进制值,并通过addrptr来存储,成功返回1,失败返回0。inet_addr进行与inet_aton相同的转换,inet_addr不能处理点分十进制字符串255.255.255.255,因为它的二进制值被用来只是函数返回失败,但是,有的编译器的INADDR_NONE不一定是这种。
注意,这3个函数操作的in_addr结构是网络字节序的。进行网络二进制和点分字符串转换最好用inet_pton和inet_ntop函数,它们是与协议无关的。
inet_pton和inet_ntop函数#include <arpa/inet.h>
int inet_pton(int family, const char *strptr, void *addrptr);
返回:成功为1,输入不是有效表达式返回0,出错为-1
const char *inet_ntop(int family, const void *addrptr, char *strptr, size_t len);
返回:成功为指向结果的指针,出错为NULL
这两个函数对于IPv4和IPv6都适用,p代表表达式(presentation)和数值(numeric)。第一个函数尝试转化有strptr指针所指的字符串,通过addptr指针存放二进制结果,成功返回1,如果对指定的family而言输入的不是有效的表达格式,那么返回0
inet_ntop进行相反的操作,如果len的值太小,不足以存放表达式结果,则返回一个空指针,并置error为ENOSPC
socket和connect函数#include <sys/socket.h>
int socket(int family, int type, int protocol);
返回:成功返回非负描述符,出错返回-1
socket函数指定期望的通信协议类型(比如使用IPv4的TCP、使用IPv6的UDP、Unix域字节流协议)和套接字字类型(字节流、数据报或原始套接字)
----socket函数的family常值------------
family 说明
AF_INET IPv4协议
AF_INET6 IPv4协议
AF_LOCAL Unix协议域
AF_ROUTE 路由套接字
AF_KEY 秘钥套接字
----------------------------------------------------
----socket函数的type常值----------------
SOCK_STREAM 字节流套接字
SOCK_DGRAM 数据报套接字
SOCK_SEQPACKET 有序分组套接字
SOCK_RAW 原始套接字
----------------------------------------------------
----socket函数的protocal常值----------
IPPROTO_CP TCP传输协议
IPPROTO_UDP UDP传输协议
IPPROTO_SCTP SCTP传输协议
----------------------------------------------------
#include <sys/socket.h>
int connect(int sockfd, const struct sockaddr* servaddr, socklen_t addrlen);
返回:成功为0,出错-1