我正在从套接字读取数据并将接收到的数据从数据报放到HostMessage。但是当我尝试显示HostMessage-> MessageHeader时,它显示无效数据。根据wireshark输出,数据报输出看起来有点不同。
我通过ntonl函数解决了这个问题(并应用于MessageHeader,而不是所有的数据报!!),b是正确的结果。使用这个解决方案,我必须将ntonl应用于所有struct成员,并且我的成员超过100个。
你有什么解决方案或想法来解决这个问题吗?
代码:
unsigned int ntonl(unsigned int a){
unsigned int b;
char* pA = (char*)&a;
char* pB = (char*)&b;
for (int i = 0; i < sizeof(pA); i++){
pB[i] = pA[(sizeof(pA)-1) - i];
}
return b;
}
void myDevice::processPendingDatagrams(){
while (m_udpSocket->hasPendingDatagrams()){
QByteArray datagram;
datagram.resize(m_udpSocket->pendingDatagramSize());
QHostAddress sender;
quint16 senderPort;
qint64 dataReceivedLength = m_udpSocket->readDatagram(datagram.data(),
datagram.size(),
&sender,
&senderPort);
tagHostMessage* HostMessage = (tagHostMessage*)datagram.data();
qDebug("datagram: %x-%x-%x-%x", datagram.data()[0], datagram.data()[1], datagram.data()[2], datagram.data()[3]);
qDebug()<<"msg header: " << HostMessage->MessageHeader[0] << "=" << HostMessage->MessageHeader;
b = ntonl(HostMessage->MessageHeader[0])
}
我的结构:
typedef struct tagHostMessage{
unsigned int MessageHeader[4];
TMessageData MessageData;
short int CheckSum;
}THostMessage,*PHostMessage;
Wireshark输出(1024byte):
0d:cc:97:e0:00:00:00:00:00:00:00:00:00:....
qDebug输出:
datagram: d-ffffffcc-ffffff97-ffffffe0
msg header: 3768044557 = 0x9be9b8
a = e097cc0d
b = 0dcc97e0
答案 0 :(得分:0)
您似乎遇到了字节顺序问题。由于QUdpSocket
继承QIODevice
,您可以在其上使用QDataStream
,此类支持字节顺序转换。指定传入数据的字节顺序:
QDataStream stream(m_udpSocket);
stream.setByteOrder(QDataStream::BigEndian); // or LittleEndian
然后你可以收到这样的数据:
unsigned int b;
stream >> b;
qToBigEndian
,qToLittleEndian
,qFromBigEndian
,qFromLittleEndian
功能也可能有用。