我想生成一个网络数据包以通过(例如)端口 123 发送到 NTP 服务器,以便我可以接收和解析返回的数据包。目标是更好地了解网络系统如何生成、读取和回复数据包。
(1) 是否应该使用结构来生成数据包?
(2) 我不确定如何正确填充结构中的各个字段;例如,是否应该使用十六进制值设置源 IP 地址和目标 IP 地址?还是有更人性化的方式?
(3) 然后,一旦填充了字段,是否可以通过 UDP 连接通过 send()/write() 将结构发送到 NTP 服务器?(或 TCP,如果协议需要它)
我的做法合理吗?我一直在阅读 NTP RFC,但仍然不确定我的客户端应该向服务器发送什么(例如 IP 地址;这不应该由网络层标头处理吗?)我已经建模了这个 NTP结构在 RFC 5905 附录 A 中的“传输”示例之后。如果我的问题措辞不当或太长,我深表歉意。预先感谢您的任何帮助。下面的代码示例借鉴了 RFC 5905 中的示例代码。
typedef unsigned long ipaddr; //32 bits (4 bytes)
typedef signed char s_char; //character type as number, -128..127
typedef unsigned int tdist; //character type as number, 0..255
typedef unsigned long long tstamp; //64 bits (8 bytes)
typedef unsigned long digest; //32 bits (4 bytes)
struct Ntp {
ipaddr dstaddr;
ipaddr srcaddr;
char version;
char leap;
char mode;
char stratum;
char poll;
s_char precision;
tdist rootdelay;
tdist rootdisp;
char refid;
tstamp reftime;
tstamp org;
tstamp rec;
tstamp xmt;
int keyid;
digest dgst;
} Ntp;
int main()
{
struct Ntp packet;
//packet.dstaddr=WHAT_GOES_HERE;
//...
//...
//packet.dgst=WHAT_GOES_HERE;
return 0;
}