有没有办法在c ++中的recv()收到的消息中检测STX(文本开头)和ETX(文本结束)字符序列?我正在尝试修复TCP中可能发生的任何部分读取,以便我可以改写完整的消息。
谢谢!
EDIT1:
通过放松来完成以下答案:
char c = '\x02';
if(memchr((*it).c_str(), c, numberOfCharactersRead) != NULL)
cout << "STX found" << endl;
我仍然无法检测到这个角色。这个实现有什么问题吗? 'it'是字符串类型向量的迭代器。
EDIT2:
这是接收数据和检查字符的完整代码:
int numberOfCharactersRead = 0;
do {
char msgBuffer[1000];
memset(msgBuffer, 0, 1000);
numberOfCharactersRead = recv(clientSideSocket, msgBuffer, (1000 - 1), 0);
if (numberOfCharactersRead < 0) {
close(clientSideSocket);
}
else if (numberOfCharactersRead == 0)
close(clientSideSocket);
else {
char c = '\x02';
if(memchr(msgBuffer, c, numberOfCharactersRead) != NULL)
cout << "STX found" << endl;
memset(msgBuffer, 0, 1000);
}
} while (numberOfCharactersRead > 0);
所以,我只是检查STX,还没有连接缓冲数据。但是,检查STX仍然失败。请告诉我这种方法的任何问题。
感谢。
EDIT3:
我为示例消息获得了以下十六进制值:
3C 31 34 32 3E 4F 63 74 20 32 35 20 31 31 3A 33 39 3A 31 32 20 6C 6F 63 61 6C 68 6F 73 74 20 5B 20 32 30 31 32 2D 4F 63 74 2D 32 35 20 31 31 3A 33 39 3A 31 32 2C 36 31 33 20 5D 20 20 20 20 49 4E 46 4F 20 7B 20 4D 61 69 6E 2E 6A 61 76 61 20 7D 20 2D 20 74 65 73 74 20 69 6E 66 6F 72 6D 61 74 69 6F 6E 20 6D 65 73 73 61 67 65 20
因此不存在STX / ETX的十六进制值。这意味着不能使用STX和ETX来检查消息的形成。
答案 0 :(得分:7)
嗯,STX和ETX不是“序列”,它们是单个字符。因此,您应该能够使用普通的memchr()
调用来搜索字符。
对于STX,character values只是'\x02'
,对于ETX,{{3}}只是'\x03'
。
请注意,您需要传入收到的尺寸。由于(我假设)无法保证部分接收的消息是0终止的,因此您无法使用strchr()
。