<meter id="pryje"><nav id="pryje"><delect id="pryje"></delect></nav></meter>
          <label id="pryje"></label>

          新聞中心

          EEPW首頁 > 嵌入式系統(tǒng) > 設(shè)計應(yīng)用 > 在Linux下利用C語言來實現(xiàn)一個Sniffer的方法簡介

          在Linux下利用C語言來實現(xiàn)一個Sniffer的方法簡介

          作者: 時間:2012-05-16 來源:網(wǎng)絡(luò) 收藏

           if (n42) {

          本文引用地址:http://www.ex-cimer.com/article/149038.htm

            perror(recvfrom():);

            printf(Incomplete packet (errno is %d)n,

            errno);

            close(sock);

            exit(0);

            }

            ethhead = buffer;

            printf(Source MAC address:

            %02x:%02x:%02x:%02x:%02x:%02xn,

            ethhead[0],ethhead[1],ethhead[2],

            ethhead[3],ethhead[4],ethhead[5]);

            printf(Destination MAC address:

            %02x:%02x:%02x:%02x:%02x:%02xn,

            ethhead[6],ethhead[7],ethhead[8],

            ethhead[9],ethhead[10],ethhead[11]);

            iphead = buffer+14; /* Skip Ethernet header */

            if (*iphead==0x45) { /* Double check for IPv4

            * and no options present */

            printf(Source host %d.%d.%d.%dn,

            iphead[12],iphead[13],

            iphead[14],iphead[15]);

            printf(Dest host %d.%d.%d.%dn,

            iphead[16],iphead[17],

            iphead[18],iphead[19]);

            printf(Source,Dest ports %d,%dn,

            (iphead[20]8)+iphead[21],

            (iphead[22]8)+iphead[23]);

            printf(Layer-4 protocol %dn,iphead[9]);

            }

            }

            }

            PF_PACKET協(xié)議簇可以讓應(yīng)用程序把數(shù)據(jù)包變成似乎從網(wǎng)絡(luò)層接收的樣子,但是沒有辦法抓到那些不是發(fā)向自己主機的包。正如我們前面看到的,網(wǎng)卡丟棄所有不含有主機MAC地址的數(shù)據(jù)包,這是因為網(wǎng)卡處于非混雜模式,即每個網(wǎng)卡只處理源地址是它自己的幀!

            只有三個例外:如果幀的目的MAC地址是受限的廣播地址(255.255.255.255)那么它將被所有的網(wǎng)卡接收:如果一個幀的目的地址是組播地址,那么它將被那些打開組播接收功能的網(wǎng)卡所接收;網(wǎng)卡如被設(shè)置成混雜模式,那么它將接收所有流經(jīng)它的數(shù)據(jù)包最后一種情況當然是我們最感興趣的了,把網(wǎng)卡設(shè)置成混雜模式,我們只需要發(fā)出一個特殊的ioctl()調(diào)用在那個網(wǎng)卡上打開一個socket,因為這是一個具有危險性的操作,所以這個調(diào)用只有具有root權(quán)限的用戶才可完成,假設(shè)那個“sock”包含一個已經(jīng)打開的socket。

          linux操作系統(tǒng)文章專題:linux操作系統(tǒng)詳解(linux不再難懂)

          上一頁 1 2 下一頁

          評論


          相關(guān)推薦

          技術(shù)專區(qū)

          關(guān)閉
          看屁屁www成人影院,亚洲人妻成人图片,亚洲精品成人午夜在线,日韩在线 欧美成人 (function(){ var bp = document.createElement('script'); var curProtocol = window.location.protocol.split(':')[0]; if (curProtocol === 'https') { bp.src = 'https://zz.bdstatic.com/linksubmit/push.js'; } else { bp.src = 'http://push.zhanzhang.baidu.com/push.js'; } var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(bp, s); })();