当前位置: 技术问答>linux和unix
一头雾水,请大家指教!
来源: 互联网 发布时间:2015-04-09
本文导语: 下面这个重定位的程序,看了整个晚上,还是看不懂,请大家多多少少给点解释, 启发也行阿 #include #include #include #include #include #include #include #include #include #include #include #define __FAVOR_BSD #include #include #d...
下面这个重定位的程序,看了整个晚上,还是看不懂,请大家多多少少给点解释,
启发也行阿
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#define __FAVOR_BSD
#include
#include
#define CHKADDRESS(_saddr_)
{
u_char *p=(char *) & (_saddr_);
if((p[0]==10)
||(p[0]==168 && 16ip_id=htons(0);
ip->ip_off=0;
#ifdef __linux
ip->ip_len=htons(iplen);
ip->ip_off=htons(IP_DF);
#else
ip->ip_len=iplen;
ip->ip_off=IP_DF;
#endif
ip->ip_ttl=2;
ip->ip_p=proto;
ip->ip_src.s_addr=target_ip;
ip->ip_dst.s_addr=dst_ip;
ip->ip_sum=0;
ip->ip_sum=checksum((u_short *)ip,sizeof(struct ip));
}
void make_icmp5_header(struct icmp *icmp,u_int gw_ip)
{
icmp->icmp_type=ICMP_REDIRECT;
icmp->icmp_code=0;//ICMP_REDIRECT_HOST;
icmp->icmp_gwaddr.s_addr=gw_ip;
icmp->icmp_cksum=0;
icmp->icmp_cksum=checksum((u_short *) icmp,8+20+8);
}
void make_udp_header (struct udphdr * udp)
{
udp->uh_sport = htons(0);
udp->uh_ulen=htons((u_short) sizeof(struct udphdr));
udp->uh_dport=htons(33434);
udp->uh_sum=htons(0);
}
u_short checksum(u_short * data,int len)
{
u_long sum=0;
for (;len>1;len-=2)
{
sum+=*data++;
if (sum& 0x80000000)
sum=(sum&0xffff)+(sum>>16);
}
if (len==1)
{
u_short i=0;
* (u_char*)(&i)=*(u_char*)data;
sum+=i;
}
while (sum>>16)
sum = (sum & 0xffff)+(sum>>16);
return(sum==0xffff)?sum:~sum;
}
启发也行阿
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#define __FAVOR_BSD
#include
#include
#define CHKADDRESS(_saddr_)
{
u_char *p=(char *) & (_saddr_);
if((p[0]==10)
||(p[0]==168 && 16ip_id=htons(0);
ip->ip_off=0;
#ifdef __linux
ip->ip_len=htons(iplen);
ip->ip_off=htons(IP_DF);
#else
ip->ip_len=iplen;
ip->ip_off=IP_DF;
#endif
ip->ip_ttl=2;
ip->ip_p=proto;
ip->ip_src.s_addr=target_ip;
ip->ip_dst.s_addr=dst_ip;
ip->ip_sum=0;
ip->ip_sum=checksum((u_short *)ip,sizeof(struct ip));
}
void make_icmp5_header(struct icmp *icmp,u_int gw_ip)
{
icmp->icmp_type=ICMP_REDIRECT;
icmp->icmp_code=0;//ICMP_REDIRECT_HOST;
icmp->icmp_gwaddr.s_addr=gw_ip;
icmp->icmp_cksum=0;
icmp->icmp_cksum=checksum((u_short *) icmp,8+20+8);
}
void make_udp_header (struct udphdr * udp)
{
udp->uh_sport = htons(0);
udp->uh_ulen=htons((u_short) sizeof(struct udphdr));
udp->uh_dport=htons(33434);
udp->uh_sum=htons(0);
}
u_short checksum(u_short * data,int len)
{
u_long sum=0;
for (;len>1;len-=2)
{
sum+=*data++;
if (sum& 0x80000000)
sum=(sum&0xffff)+(sum>>16);
}
if (len==1)
{
u_short i=0;
* (u_char*)(&i)=*(u_char*)data;
sum+=i;
}
while (sum>>16)
sum = (sum & 0xffff)+(sum>>16);
return(sum==0xffff)?sum:~sum;
}
|
你说的是ICMP Redirect吧?
不知道你不明白的是什么?不明白ICMP Redirect的概念?
稍做一下解释:
假设HostA与多个网络连接,默认的Gateway是RouterA,如果HostA想与别的网络主机B相连接,如果HostA上没有到B的路由,就只能把包发给RouterA,但是RouterA经过检查自己的路由表,发现RouterA需要把包发给RouterB,但是RouterB与HostA也是直接相连,所以从HostA到RouterA的过程就是多余的,所以RouterA就发给HostA一个ICMP Redirect,通知HostA到HostB的默认路由是RouterB。
ICMP Redirect的具体结构是:
IP头(20字节)+ICMP头(8字节)(其中一个字节的type:5,代表ICMP Redirect,一个字节的code:0-3, 2个字节的checksum, 4个字节的正确路由信息)+HostA的IP头(20字节)+HostA的信息,比如说UDP信息(8字节)。
上边的程序就是具体构造这个包而已,其中他的CHKADDRESS没有用,是做测试用的。
而且注意他的TTL设成了2,是为了保证这个Redirect包只在本地网才存在。
具体的东西,请参看 TCP/IP详解,卷一:协议,我看的是英文版的,是Section 9.5 P119
如果你还是不明白的化,我就没有办法了。
不知道你不明白的是什么?不明白ICMP Redirect的概念?
稍做一下解释:
假设HostA与多个网络连接,默认的Gateway是RouterA,如果HostA想与别的网络主机B相连接,如果HostA上没有到B的路由,就只能把包发给RouterA,但是RouterA经过检查自己的路由表,发现RouterA需要把包发给RouterB,但是RouterB与HostA也是直接相连,所以从HostA到RouterA的过程就是多余的,所以RouterA就发给HostA一个ICMP Redirect,通知HostA到HostB的默认路由是RouterB。
ICMP Redirect的具体结构是:
IP头(20字节)+ICMP头(8字节)(其中一个字节的type:5,代表ICMP Redirect,一个字节的code:0-3, 2个字节的checksum, 4个字节的正确路由信息)+HostA的IP头(20字节)+HostA的信息,比如说UDP信息(8字节)。
上边的程序就是具体构造这个包而已,其中他的CHKADDRESS没有用,是做测试用的。
而且注意他的TTL设成了2,是为了保证这个Redirect包只在本地网才存在。
具体的东西,请参看 TCP/IP详解,卷一:协议,我看的是英文版的,是Section 9.5 P119
如果你还是不明白的化,我就没有办法了。