Linux/UNIX网络编程甘刚电子教案 第02章 基本套接口编程.ppt
文本预览下载声明
基本套接字编程 主要内容 套接字基础 套接字地址结构 套接字基本函数 套接字基础 网络编程接口有两个发展方向:Socket,TLI 套接字是一种网络API,程序员可以用之开发网络程序。 套接字类型 套接字支持多种通信协议: Unix:Unix系统内部协议 INET:IP版本4 INET6:IP版本6 Linux支持多种套接字类型,即应用程序希望的通信服务类型 SOCKET_STREAM:双向可靠数据流,对应TCP SOCKET_DGRAM:双向不可靠数据报,对应UDP SOCKET_RAW:是低于传输层的低级协议或物理网络提供的套接字类型,可以访问内部网络接口。例如接收和发送ICMP报 套接字地址结构(IPv4) 大多数套接字函数需要一个指向套接字地址结构的参数,每个协议族都定义它自己的套接字地址结构,一般以”sockaddr_”开头,并以协议簇为后缀。(netinet/in.h) struct sockaddr_in server …… bzero(server,sizeof(server)) server.sin_family=AF_INET; server.sin_port=htons(PORT); server.sin_addr.s_addr = htonl(INADDR_ANY) ……. 套接字地址结构(IPv6) IPv6地址为128位。(netinet/in.h) IPv4与IPv6地址结构比较 通用套接字地址结构 由于套接字函数需接收来自不同协议的地址结构,ANSI的办法是使用通用的指针类型,即(void *).套接字函数方法是定义一个通用的套接字地址结构。sys/socket.h 字节排序函数 为保证”大端“和”小端“字节序的机器之间能相互通信,需在发送多字节整数时,将主机字节序转换成网络字节序,或反之。 字节排序函数(cont.) #include netinet/in.h uint16_t htons(uint16_t hostshort) uint32_t htonl(uint32_t hostlong) 均返回:网络字节序值 uint16_t ntohs(uint16_t netshort) uint32_t ntohl(uint32_t netlong) 均返回:主机字节序值 h:主机 n:网络 s:短整数 l:长整数 字节操纵函数 #include string.h void bzero(void *dest, size_t nbytes); void bcopy(const void *src, void *dest, size_t nbytes); int bcmp(const void *src, void *dest, size_t nbytes); /*返回0则相同,非0不相同*/ 上述三个函数源自BSD void *memset(void *dest, int c, size_t len); void *memcpy(void *dest, const void *src, size_t nbytes); int memcmp(const void *ptr1, const void *ptr2, size_t nbytes) 上述三个函数属于ANSI C 地址转换函数 #include arpa/inet.h 将点分十进制数串转换成32位网络字节序二进制值。 int inet_aton(const char *cp, struct in_addr *inp); 返回:1-串有效,0-串有错 in_addr_t inet_addr(const char *cp); 返回:若成功,返回32位二进制的网络字节序地址,若有错,则返回一个 常值INADDR_NONE(32位均为1). 过时函数 inet_aton函数将cp所指的字符串(点分十进制数串,如192.168.0.1)转换成32位的网络字节序二进制,并通过指针inp来存储。这个函数需要对字符串所指的地址进行有效性验证。但如果cp为空,函数仍然成功,但不存储任何结果。 inet_addr进行相同的转换,但不进行有效性验证,也就是说,所有232种可能的二进制值对inet_addr函数都是有效的。 地址转换函数(续) char *inet_ntoa(struct in_addr inaddr
显示全部