我已经编写了一个非常小的ntp客户端,但是在发送数据包之后,我没有收到服务器的响应,我已经用tcpdump确认了该响应。
我定义了一个结构,该结构用于传输ntp数据包。
struct NtpMessage_t {
unsigned int first_line;
unsigned int root_delay;
unsigned int root_dispertion;
unsigned int ref_id;
unsigned long long ref_timestamp;
unsigned long long origin_timestamp;
unsigned long long receive_timestamp;
unsigned long long transmit_timestamp;
};
用
message->first_line = 0b00100011000000000000000000000000;
填充数据包后,我将数据包发送到de.ntp.pool.org
,但没有收到响应。套接字初始化以及消息的发送和接收是通过以下代码完成的:for (i = result; i != NULL; i = i->ai_next) {
cfd = socket(i->ai_family, i->ai_socktype, i->ai_protocol);
if (cfd != -1)
break;
}
if (i == NULL) {
fprintf(stderr, "Failed to create socket\n");
exit(EXIT_FAILURE);
}
NtpMessage *message = calloc(1, sizeof(NtpMessage));
message->first_line = 0b00100011000000000000000000000000;
if (sendto(cfd, message, sizeof(NtpMessage), 0, (struct sockaddr *) i->ai_addr, i->ai_addrlen) < 0) {
printf("Send failure: %s\n", strerror(errno));
exit(EXIT_FAILURE);
}
if (recvfrom(cfd, message, sizeof(NtpMessage), 0, (struct sockaddr *) &from_addr, &from_addr_len) < 0) {
printf("Receive failure: %s\n", strerror(errno));
exit(EXIT_FAILURE);
}
Tcpdump提供了以下输出,据我了解,我的消息已正确发送,但未收到任何答复:
MY_IP_ADDR.50318 > 64.99.80.121.123: [udp sum ok] NTPv0, length 48
unspecified, Leap indicator: (0), Stratum 0 (unspecified), poll 0 (1s), precision 35
Root Delay: 0.000000, Root dispersion: 0.000000, Reference-ID: (unspec)
Reference Timestamp: 0.000000000
Originator Timestamp: 0.000000000
Receive Timestamp: 0.000000000
Transmit Timestamp: 0.000000000
Originator - Receive Timestamp: 0.000000000
Originator - Transmit Timestamp: 0.000000000
由于没有其他方向的消息,因此,如果我没有记错的话,则意味着没有响应。是这样,如果是,这里出了什么问题?我的代码有问题吗?
最佳答案
您可能有很多原因导致服务器不对您的ntp数据包发出响应。我看到您的示例中确实隐藏了几件事,因此很可能是问题是对NTP协议规范的无知。
您如何填充数据包内容?您是否检查过编译器备用字节以填补结构对齐的空白?您是否考虑过,在NTP协议中,所有的short,int和64bit时间戳都必须按照网络字节顺序排列(最高有效字节在前)?
最后,NTP服务器通过忽略传入的数据包来对不正确的输入进行操作,但是您认为数据包是正确的。
关于c - NTP服务器未响应我的客户端,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/48244594/