解决QTcpSocket发送数据成功,但接收端接收不全的问

createh55个月前 (02-01)技术教程33

这里主要是这样的Qt写了一个服务端,在开发环境下,没出现任何问题,但在生产环境下,就出现问题了。

使用Fiddler的简单抓了下包:

发现Body只有27045,而请求里面确是这样的。


这里就很有意思了。

这里的Qt服务端,在发送完数据后,会主动和客户端断开连接。不像其他的web服务器,需要等客户端来断开连接。

这里用curl请求会有报错:

transfer closed with 25527 bytes remaining to read

大体上的意思就还有这么多位的数据没读,通道就被关闭了。

在Qt服务端关于关闭的代码是这样的:

tcpSocket->write(HttpResponse::message(json->toJson()).toUtf8());
tcpSocket->waitForBytesWritten();
tcpSocket->disconnectFromHost();

并且这个tcpSocket->write的返回值,也是正确的,说明的确把要发送的数据送到了网卡中让其发送。并且waitForBytesWritten也是返回true的。

个人感觉主要的问题就是tcpSocket->waitForBytesWritten(),可能是Qt的一个BUG,我这里用的是5.5.1

感觉这里Qt做的没有我想象中的那样。

这里的解决办法有3个:

①数据分包发送,有些web服务器会把发送的数据分成几个包发送给客户端。这种方式就能解决上面的问题。

②简单修改下代码逻辑,比如改成了这样的:

qint64 writeSize = tcpSocket->write(HttpResponse::message(json->toJson()).toUtf8());
qDebug() << "writeSize: " << writeSize;
 
if(!tcpSocket->waitForBytesWritten(10 * 1000)){
 
    qDebug() << "error:" << tcpSocket->errorString();
}
 
if(!tcpSocket->waitForDisconnected(10 * 1000)){
 
    tcpSocket->disconnectFromHost();
}
delete json;
delete tcpSocket;

③加一个waitForDisconnected()如下:

tcpSocket->disconnectFromHost();
tcpSocket->waitForDisconnected();

建议优先用第三种,不行就再考虑第一种和第二种。

相关文章

用了这么久,token和session的区别,你真的清楚了吗?

session和token都是用来保持会话,功能相同一、session机制,原理session是服务端存储的一个对象,主要用来存储所有访问过该服务端的客户端的用户信息(也可以存储其他信息),从而实现保...

学习必备|分布式即时通讯服务端java版附源码

今日推荐:分布式即时通讯服务端推荐一款基于java开发的分布式即时通讯服务端,网络基于netty,akka实现实时信息,提供简单的API服务 ,方便二次开发。特点:1、支持单击部署,也支持集群部署2、...

拒绝接口裸奔!开放API接口签名验证

接口安全问题请求身份是否合法?请求参数是否被篡改?请求是否唯一?AccessKey&SecretKey (开放平台)请求身份为开发者分配AccessKey(开发者标识,确保唯一)和SecretKey(...

新公司还是使用SVN,一怒之下写了这篇保姆级小白教程

现在一般开发都是协同开发了,所以会用到版本控制系统,说白了就是大家一起开发一个项目,分别写不同的代码,然后需要把代码汇总到一起,大家可能互相需要对方写的代码,就是大家共同去写一套代码,这就是需要版本控...

Redis Java 客户端 Lettuce(生菜)食用指南

Lettuce 这个名字蛮有意思,音标:[?let?s] ,发音和 Jedis ,Redis 一样都比较押韵,Lettuce 的中文意思是生菜,官方网站()的 Logo 就是一朵生菜,网页也是一片绿油...