我已经编写了一个非常小的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/

10-14 14:44