0

好的,这是一个非常奇怪的问题。我试图创建一个原始套接字 ICMP 数据包来欺骗 ping 请求。

int s;
s = socket(PF_INET, SOCK_RAW, IPPROTO_RAW);

接着

int one; // I should initialize it as 1, but I didn't. 
const int *val = &one;
setsockopt(s, IPPROTO_IP, IP_HDRINCL, val, sizeof(one));
....

事实证明,由于我没有将一个初始化为 1,所以被欺骗的客户端无法收到 ping 回复。但是,当我添加一个

unsigned char *ch = (unsigned char *)spoof;

就在之前

close(s);,

事实证明,被欺骗的客户端可以收到 ping 回复。这是为什么?

4

1 回答 1

4

当您未能初始化自动存储时,它获得的值取决于您的程序最后一次使用它的用途,甚至是在同一 VM 空间中运行的前一个程序。因此,任何事情都可能发生。添加这行代码只是导致one堆栈上的值的对齐方式不同。该变量中的垃圾在其新位置允许原始套接字工作。另一个没有。这是运气。

于 2013-02-06T04:04:55.960 回答