Linux netfilterÔ´Âë·ÖÎö(1)
תÌù×Ô:http://alexanderlaw.blog.hexun.com/8960896_d.html
Linux netfilterÔ´Âë·ÖÎö(1)
ÄÚÈÝ»ù±¾ÉÏÀ´×ÔÁ½ÆªÎÄÕÂ:
¡¶NetfilterÔ´Âë·ÖÎö¡·—£¨¶À¹Â¾Å¼úhttp://www.skynet.org.cn/index.php£©
¡¶Linux NetfilterʵÏÖ»úÖÆºÍÀ©Õ¹¼¼Êõ¡·——£¨ÑîɳÖÞ ¹ú·À¿Æ¼¼´óѧ¼ÆËã»úѧԺ£©
Ò»¡¢ IP±¨ÎĵĽÓÊÕµ½hookº¯ÊýµÄµ÷ÓÃ
1.1 ip_input.c ip_rcv()º¯Êý
ÒÔ½ÓÊÕµ½µÄ±¨ÎÄΪÀý£¬ÀàËÆµÄ»¹ÓÐip_forward(ip_forward.c)ºÍip_output(ip_output.c)
int ip_rcv(struct sk_buff *skb, struct net_device *dev, struct packet_type *pt, struct net_device *orig_dev)
{
struct iphdr *iph; //¶¨ÒåÒ»¸öip±¨ÎĵÄÊý¾Ý±¨Í·
u32 len;
if (skb->pkt_type == PACKET_OTHERHOST)
goto drop; //Êý¾Ý°ü²»ÊÇ·¢¸øÎÒÃǵÄ
IP_INC_STATS_BH(IPSTATS_MIB_INRECEIVES); //ÊÕµ½Êý¾Ý°üͳ¼ÆÁ¿¼Ó1
if ((skb = skb_share_check(skb, GFP_ATOMIC)) == NULL)
{
/* Èç¹ûÊý¾Ý±¨Êǹ²ÏíµÄ£¬Ôò¸´ÖÆÒ»¸ö³öÀ´£¬´Ëʱ¸´Öƶø³öµÄÒѾºÍsocketÍÑÀëÁ˹ØÏµ */
IP_INC_STATS_BH(IPSTATS_MIB_INDISCARDS);
goto out;
}
if (!pskb_may_pull(skb, sizeof(struct iphdr)))
goto inhdr_error; //¶ÔÊý¾Ý±¨µÄÍ·³¤¶È½øÐмì²é£¬
iph = skb->nh.iph; //È¡µÃÊý¾Ý±¨µÄÍ·²¿Î»ÖÃ
if (iph->ihl < 5 || iph->version != 4) //°æ±¾ºÅ»òÕßÍ·³¤¶È²»¶Ô£¬
goto inhdr_error; //Í·³¤¶ÈÊÇÒÔ4×Ö½ÚΪµ¥Î»µÄ£¬ËùÒÔ5±íʾµÄÊÇ20×Ö½Ú
if (!pskb_may_pull(skb, iph->ihl*4))
goto inhdr_error;
if (unlikely(ip_fast_csum((u8 *)iph, iph->ihl)))
goto inhdr_error; //¼ì²é±¨ÎĵļìÑéºÍ×Ö¶Î
len = ntohs(iph->tot_len);
if (skb->len < len || len < (iph->ihl*4))
goto inhdr_error; //Õû¸ö±¨Îij¤¶È²»¿ÉÄܱȱ¨Í·³¤¶ÈС
if (pskb_tr
Ïà¹ØÎĵµ£º
ÕâÆªÎÄÕ»ù±¾ÉϽ²Ã÷°×ÁËÈçºÎ°²×°LinuxÏ嵀 vmtools£¬²»¹ýÎÒºÍËûµÄ°²×°²»Í¬£¬ËùÒÔ½ö¹©²Î¿¼£¬¾ßÌåʵÏÖÒª¿´ÊÇÄÇÖÖLinuxϵͳ£¬»òÕßÊǾßÌåµÄÄǸö°æ±¾£¬ÎÒÓÃredhatºÍubuntu¡£»ù±¾²Ù×÷¾ÍÊÇ£º
¹ÒÔØ¹âÇý¡¢¸´ÖÆÎļþµ½tmp¡¢½âѹ¡¢°²×°¡¢Ò»Â·Ä¬ÈÏ¡¢°²×°Íê³É¡£
1¡¢ÒÔROOTÉí·Ý½øÈëLINUX
2¡¢°´Ï CTRL+ALT×éºÏ¼ü£¬½øÈëÖ÷²Ù×÷ϵͳ£ ......
Ó²¼þ¼¼ÊõÒ»Ö±ºÍÈí¼þ¼¼ÊõÏàÒÀÏàËæ£¬Ëæ×Å·þÎñÆ÷Ó²¼þºÍоƬ¼¼ÊõµÄ½ø²½£¬Íƶ¯×Å·þÎñÆ÷²Ù×÷ϵͳ¼¼ÊõµÄ±ä¸ï¡£
¡¡¡¡Ð¾Æ¬¼¼ÊõµÄ·¢Õ¹£º´Óx86µ½Áúо
¡¡¡¡2009Ä꣬¸÷´óоƬ³§É̶¼ÍƳöÁ˶à¿îоƬ²úÆ·£ºÈçIntel¹«Ë¾»ùÓÚNehalem¼Ü¹¹·¢²¼µÄ×ÀÃæ¶ËоƬ²úÆ·¿áî£i7;AMD¹«Ë¾Ò²ÍƳöÁË»ù
ÓÚÐÂFioranoƽ̨µÄ´úºÅΪ“ÒÁ˹̹²¼¶û”µÄÁù ......
linuxÏÂÓÐרÃŵÄÎļþϵͳÓÃÀ´¶ÔÉ豸½øÐйÜÀí£¬devfsºÍsysfs¾ÍÊÇÆäÖÐÁ½ÖÖ¡£
1£¬devfs£ºdevfsÊÇÔÚ2.4Äں˾ͳöÏÖÁË£¬ËüÊÇÓÃÀ´½â¾ölinuxÖÐÉ豸¹ÜÀí»ìÂÒµÄÎÊÌ⣬linuxÄں˿ª·¢ÈËÔ±¿ª·¢ÁËdevfs¡£
2£¬sysfs£ºÊÇLinux ÄÚºËÖÐÉè¼Æ½ÏеÄÒ»ÖÖÐéÄâµÄ»ùÓÚÄÚ´æµÄÎļþϵͳ£¬ËüµÄ×÷ÓÃÓëproc ÓÐЩÀàËÆ£¬µ« ......
xmanager secureCRT½áºÏʹÓÃ
»·¾³£ºÔÚxpÖа²×°ÐéÄâ»úvmware £¬host-only·½Ê½ÐéÄâLinuxϵͳ¡£xpµÄipΪ192.168.0.1£¬ÐéÄâ»úLinuxΪ192.168.0.88
ÔÚxpÖа²×°xmanagerºÍsecureCRT £¬Ä¬ÈÏÇé¿öÏÂCRT²»ÄÜÏÔʾͼÐνçÃæ£¬Í¨¹ýÒÔÏÂÅäÖÿÉÒÔʵÏÖÔÚWindowsϵÄCRTÀïÏÔʾLinuxÖеÄoracleͼÐνçÃæ£º
ÒÔoracleÓû§µÇ½Linux£¬ÐÞ¸Ä.ba ......