我有关于QUdpSocket的问题:
我大约每0.2秒在端口50011
上接收到多播地址239.0.0.1
的UDP消息(由wireshark证明)。
以下代码运行良好(并在每条消息上打印" VALID")约1分钟。之后messageHandler
信号QUdpSocket's
不再调用readyRead
(即使我已经使用wireshark进行了双重检查,并且仍在发送消息)。
ServiceDiscovery::ServiceDiscovery(QObject *parent) :
QObject(parent),
socket(new QUdpSocket(this))
{
socket->bind(QHostAddress::AnyIPv4, 50011, QUdpSocket::ShareAddress);
socket->joinMulticastGroup(QHostAddress("239.0.0.1"));
connect(socket, &QUdpSocket::readyRead,
this, &ServiceDiscovery::messageHandler,
Qt::DirectConnection);
}
void ServiceDiscovery::messageHandler()
{
if(socket->isOpen()) qDebug("OPEN"); // Does not print, ofc.
if(socket->isReadable()) qDebug("READABLE"); // Does not print.
if(socket->isValid()) qDebug("VALID"); // Suddenly stops.
QByteArray datagram;
while(socket->hasPendingDatagrams()) {
datagram.resize(socket->pendingDatagramSize());
socket->readDatagram(datagram.data(), datagram.size());
Message response(datagram);
if(response.deserialize()) {
if(response.getServiceID() == constants::servicediscovery::SERVICE_ID) {
QByteArray payload = response.getPayload();
if(payload.size() >= 48) {
QString address = QHostAddress(payload.mid(32, 4).toHex().toUInt(nullptr, 16)).toString();
quint16 port = payload.mid(38, 2).toHex().toUInt(nullptr, 16);
emit found(address, port);
}
}
}
}
}
我在这里做错了什么? 提前谢谢。
编辑:由于评论,我也粘贴了数据报处理。
答案 0 :(得分:0)
记录: 我有同样的问题。原因:我的应用程序依赖的演示库在评估时间后关闭,不仅其开放端口而且应用程序的所有端口。