Linux平台C语言http返回response报文接收不全的解决方法

前言

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));
}

觉得有用的话,可以给我点奖励哦!(微信)
在这里插入图片描述

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
下面是一个简单的用C语言实现发送接收报文的示例程序,该程序使用了套接字(socket)编程接口: ```c #include <stdio.h> #include <stdlib.h> #include <string.h> #include <sys/socket.h> #include <arpa/inet.h> #define PORT 8888 #define BUFFER_SIZE 1024 int main() { int sock = socket(AF_INET, SOCK_DGRAM, 0); if (sock == -1) { perror("Failed to create socket"); exit(EXIT_FAILURE); } struct sockaddr_in serverAddr, clientAddr; memset(&serverAddr, 0, sizeof(serverAddr)); memset(&clientAddr, 0, sizeof(clientAddr)); serverAddr.sin_family = AF_INET; serverAddr.sin_addr.s_addr = INADDR_ANY; serverAddr.sin_port = htons(PORT); if (bind(sock, (struct sockaddr*)&serverAddr, sizeof(serverAddr)) == -1) { perror("Failed to bind socket"); exit(EXIT_FAILURE); } char buffer[BUFFER_SIZE]; memset(buffer, 0, sizeof(buffer)); socklen_t clientAddrLen = sizeof(clientAddr); int receiveLen = recvfrom(sock, buffer, BUFFER_SIZE, 0, (struct sockaddr*)&clientAddr, &clientAddrLen); if (receiveLen == -1) { perror("Failed to receive data"); exit(EXIT_FAILURE); } printf("Received message: %s\n", buffer); char* replyMsg = "Hello, I am server!"; int sendLen = sendto(sock, replyMsg, strlen(replyMsg), 0, (struct sockaddr*)&clientAddr, clientAddrLen); if (sendLen == -1) { perror("Failed to send data"); exit(EXIT_FAILURE); } printf("Reply message sent\n"); close(sock); return 0; } ``` 该程序创建了一个UDP协议套接字,绑定到本地的8888端口,并且通过 `recvfrom` 函数接收客户端发送的报文,然后通过 `sendto` 函数发送回复报文给客户端。注意,该程序中的IP地址是通过 `INADDR_ANY` 宏指定的,表示可以接收来自任意IP地址的报文。如果要限制只接收来自特定IP地址的报文,可以使用 `inet_addr` 函数将IP地址转换为网络字节序的二进制形式,然后将其赋值给 `serverAddr.sin_addr.s_addr` 字段。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

lichaofan2008

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值