前言
Linux平台C语言开发中,接收http返回报文时,我们会使用read()、recv()函数。
当http返回报文较大、数据过长时,会概率性出现读取不全、接收不全的情况。
此时,怎么办呢?
办法就是:再读一次!
首先,我们发出http请求后,因为服务器处理要耗时,所以,首次读取,我们一般会设置较长的超时时间,或者不设置保持默认的超时时间;(首次读取,会概率性读取不全)
然后,我们设置较短的超时时间(如10ms),再读一次;(再读一次可能还是读取不全,那就再一次,所以使用了while())
最后,直到什么都没读取到,函数超时,返回-1;(至此,我们就可以保证读取完了所以返回报文的数据,可以进行解析了)
C代码
// 时间结构体
struct timeval _tm;
while (1) {
_len = read(_sockfd, _str1, 1024);
//LOGD("postFormData(): read LENGTH= %d", _len);
// 超时会返回-1
if (_len <= 0) {
break;
}
// 保存每次读取的片段,拼接到一起
memcpy(_recvStr + _readSize, _str1, _len);
_readSize += _len;
// 超时时间设置,后续包耗时较小
_tm.tv_sec = 0;
_tm.tv_usec = 10000;
// 设置接收超时
setsockopt(_sockfd, SOL_SOCKET, SO_RCVTIMEO, &_tm, sizeof(struct timeval));
}
觉得有用的话,可以给我点奖励哦!(微信)