套接字网络编程笔记
套接字网络编程笔记
1.调用int send( __in SOCKET s, __in const char* buf, __in int len, __in int flags); 发出的数据包,在传送过程中,虽然顺序不会把打乱,但可能会拆分成多个包,这样,只调用一次int recv( __in SOCKET s, __out char* buf, __in int len, __in int flags); 可能不能被完整地接收。
解决的方法是,定义TCP之上的协议,即应用层协议,指示数据包长度。最简单的实现为:
- void SendFn(SOCKET s, char* data, int len)
- {
- char* buff = (char*)malloc(sizeof(int)+len);
- //填充报文头
- int* pLen = (int*)buff;
- *pLen = len;
- //填充有效数据
- memcpy(buff+sizeof(int), data, len);
- send(s, buff, sizeof(int)+len, 0);
- }
- //完整接收指定长度数据包
- void RecvFnS(SOCKET s, char* buff, int len)
- {
- int done = 0;
- done = recv(s, buff, len, 0);
- while ( done < len )
- done += recv(s, buff+done, len, 0);
- }
- void RecvFn(SOCKET s)
- {
- int len;
- //接收报文头
- RecvFnS(s, (char*)&len, sizeof(int));
- //接收有效数据
- if ( len > 0 )
- {
- char* buff = (char*)malloc(len);
- RecvFnS(s, buff, len);
- }
- }
2.TCP通信时,服务器用SOCKET accept( __in SOCKET s, __out struct sockaddr* addr, __inout int* addrlen); 创建的套接字共同占用一个端口,即服务器监听端口。
为什么要这么做:客服端套接字指定通信对方的端口就是监听端口,没有理由找一个使用其它端口的套接字跟它连接。
为什么能这么做:TCP报文中,包含源端口,与目标端口,再加上IP层的源IP地址及目标IP地址,这四个信息,就是运输层多路分解中,所需要的四元组,意思是可以唯一确定一个TCP连接。当从IP层,解包数据后,就可以根据四元组,找到这些数据的目标TCP连接。这点跟UDP连接是有区别的,因为UDP多路分解时只使用目标IP地址及目标端口,所以,只要目标IP为本机IP,目标端口为监听端口的,UDP连接都会定向到一个UPD连接。这意味,UDP是一个一对多的连接(确切地说UPD不能叫连接)。
|
评论暂时关闭