IPv6监听::地址
1、linux和window均可以在监听此地址时,使能或者关闭双栈,使用参数IPPROTO_IPV6, IPV6_V6ONLY。
#ifndef socklen_t
#define socklen_t int
#endif
int isIpv6Only = ipv6only ? 1 : 0;
socklen_t len = (socklen_t)sizeof(int);
int ret = setsockopt(fd, IPPROTO_IPV6, IPV6_V6ONLY, (char*)&isIpv6Only, len);
Window打开双栈监听:
linux打开双栈监听
linux上虽然只监听IPv6地址,但是依然可以接收127.0.0.1的连接请求,从accept中返回的文件描述符,获取其连接信息如下:
peer addr:::ffff:127.0.0.1, peer port:47155, local addr:::ffff:127.0.0.1, local port:11111
windows虽然监听了0.0.0.0,但是来自于127.0.0.1的连接信息如下:
关闭双栈,使用127.0.0.0连接监听::的服务,连接失败