當(dāng)前位置:首頁 > 嵌入式 > 嵌入式軟件
[導(dǎo)讀]在Linux下利用C語言來實現(xiàn)一個Sniffer的方法簡介

Sniffer技術(shù)是網(wǎng)絡(luò)安全領(lǐng)域里一項非常重要的技術(shù)!對于“Hacker”來說,他們可以以非常隱蔽的方式得到網(wǎng)絡(luò)中傳輸?shù)拇罅康拿舾行畔ⅲ?Telnet,ftp帳號和密碼等等明文傳送的信息!與主動掃描相比,嗅探的行為更加難以被察覺,操作起來也不是很復(fù)雜!對于網(wǎng)絡(luò)管理人員來說,可以利用嗅探技術(shù)對網(wǎng)絡(luò)活動進行監(jiān)控,并及時發(fā)現(xiàn)各種攻擊行為!

  在這篇文章里,我們主要探討在Linux下如何利用C語言來實現(xiàn)一個Sniffer!我們將假設(shè)所有的主機在一個局域網(wǎng)內(nèi)。

  首先,我們將簡短的回顧一下一個普通的以太網(wǎng)卡是怎么工作的!(如果你對這方面的知識早已熟悉,那么你可以直接跳到下一段)來源于應(yīng)用程序的IP報文被封裝成以太網(wǎng)幀(這是在以太網(wǎng)上傳播的數(shù)據(jù)報文的名稱),它是底層鏈路層報文上面的一層報文,包含有源地址報文和一些需要用來傳送至目標主機的信息。通常情況下,目的IP地址對應(yīng)著一個6字節(jié)的目的以太網(wǎng)址(經(jīng)常叫做MAC地址),它們之間通過ARP協(xié)議進行映射!就這樣,包含著以太網(wǎng)幀的報文從源主機傳輸?shù)侥康闹鳈C,中間經(jīng)過一些網(wǎng)絡(luò)設(shè)備,如交換機,路由器等等,當(dāng)然,因為我們的前提是主機在同一網(wǎng)內(nèi),所以我們的討論不涉及以上這些網(wǎng)絡(luò)設(shè)備!

  在鏈路層中并不存在路線的概念,換句話說,源主機發(fā)出的幀不會直接指向目的主機,而是基于廣播方式傳播,網(wǎng)絡(luò)中的所有網(wǎng)卡都能看到它的傳輸。每個網(wǎng)卡會檢查幀開始的6個字節(jié)(目的主機的MAC地址),但是只有一個網(wǎng)卡會發(fā)現(xiàn)自己的地址和其相符合,然后它接收這個幀,這個幀會被網(wǎng)絡(luò)驅(qū)動程序分解,原來的IP 報文將通過網(wǎng)絡(luò)協(xié)議棧傳送至接收的應(yīng)用程序!

  更準確的說,網(wǎng)絡(luò)驅(qū)動程序會檢查幀中報文頭部的協(xié)議標識,以確定接收數(shù)據(jù)的上層協(xié)議!大多數(shù)情況下,上層是IP協(xié)議,所以接收機制將去掉IP報文頭部,然后把剩下的傳送至UDP或者TCP接收機制!這些協(xié)議,將把報文送到SOCKET-handling機制,它將最后把報文數(shù)據(jù)變成應(yīng)用程序可接收的方式發(fā)送出去。在這個過程中,報文將失去所有的和其有關(guān)的網(wǎng)絡(luò)信息,比如源地址(IP和MAC),端口號,IP選擇,TCP參數(shù)等等!所以如果目的主機沒有一個包含正確參數(shù)的打開端口,那么這個報文將被丟棄而且永遠不會被送到應(yīng)用層去!

  因此我們在進行網(wǎng)絡(luò)嗅探的時候有兩個不同的問題:一個和以太網(wǎng)址有關(guān),我們不能抓到不是發(fā)給自己主機的包,另一個和協(xié)議棧的運行過程有關(guān),我們需要一個socket去*每個端口,得到那些沒有被丟棄的報文!

  第一個問題不是最根本的,因為我們可能不會對發(fā)往其他主機的報文有興趣而只想嗅探所有發(fā)往自己主機的報文。第二個問題是必須要解決的,下面我們將看到這個問題是怎么樣一步一步解決的!

  當(dāng)你打開一個標準的SOCKET套接字時,你需要指明你將使用哪個協(xié)議簇,大多數(shù)情況下我們一般用PF_UNIX在本地機器間進行通信,PF_INET在基于IPv4協(xié)議簇基礎(chǔ)之上進行通信,你還需要指明所用的協(xié)議類型及與協(xié)議簇相關(guān)的確切數(shù)值,,在PF_INET協(xié)議簇中,常用的有 SOCK_STREAM(與TCP相關(guān)),SOCK_DGRAM(與UDP相關(guān))。在把報文發(fā)送到應(yīng)用程序前內(nèi)核對其的處理與SOCKET類型有關(guān),你指定的協(xié)議將處理報文在SOCKET的傳輸!(具體細節(jié)問題你可以man socket(3))

  在LINUX內(nèi)核版本中(2.0 releases),一個名為PF_PACKET的協(xié)議簇被加了進來!這個簇允許應(yīng)用程序直接利用網(wǎng)絡(luò)驅(qū)動程序發(fā)送和接收報文,避免了原來的協(xié)議棧處理過程,在這種情況下,所有SOCKET發(fā)出的報文直接送到以太網(wǎng)卡接口,而接口收到的任何報文將直接送到應(yīng)用程序The PF_PACKET協(xié)議簇支持兩個稍微有點不同的SOCKET類型,SOCK_DGRAM和SOCK_RAW。

  前者讓內(nèi)核處理添加或者去除以太網(wǎng)報文頭部工作,而后者則讓應(yīng)用程序?qū)σ蕴W(wǎng)報文頭部有完全的控制!在SOCKET調(diào)用中的協(xié)議類型必須符合/usr /include/linux/if_ether.h中定義的以太網(wǎng)IDs中的一個,除非遇到特別聲明的協(xié)議,一般你可以用ETH_P_IP來處理IP的一組協(xié)議(TCP,UDP,ICMP,raw IP等等)因為它們?nèi)菀资艿揭恍┖車乐氐陌踩珕栴}的牽連(比如你可以偽造一個MAC地址),所以只有具有root權(quán)限才可以使用PF_PACKET- familysocket.這也就是為什么只有具有root權(quán)限后才能運行嗅探器的原因!

  PF_PACKET-family 協(xié)議簇可以很容易解決協(xié)議棧處理嗅探來的數(shù)據(jù)報文時候遇到的問題!我們一起來看看程序1,我們打開一個屬于PF_PACKET-family 協(xié)議簇的SOCKET,指定一個SOCK_RAW socket類型和IP相關(guān)協(xié)議類型。這時我們開始從SOCKET抓包,在一些相關(guān)檢查后.我們開始得到從鏈路層和IP層抓來的頭部信息,。通過閱讀程序一,你將會發(fā)現(xiàn)讓應(yīng)用程序從網(wǎng)絡(luò)層抓包其實并不難!

  Example 1.

  #include

  #include

  #include

  #include

  #include

  #include

  #include

  int main(int argc, char **argv) {

  int sock, n;

  char buffer[2048];

  unsigned char *iphead, *ethhead;

  if ( (sock=socket(PF_PACKET, SOCK_RAW,

  htons(ETH_P_IP)))<0) {

  perror("socket");

  exit(1);

  }

  while (1) {

  printf("----------n");

  n = recvfrom(sock,buffer,2048,0,NULL,NULL);

  printf("%d bytes readn",n);

  /* Check to see if the packet contains at least

  * complete Ethernet (14), IP (20) and TCP/UDP

  * (8) headers.

  */[!--empirenews.page--]
 if (n<42) {

  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ù)包最后一種情況當(dāng)然是我們最感興趣的了,把網(wǎng)卡設(shè)置成混雜模式,我們只需要發(fā)出一個特殊的ioctl()調(diào)用在那個網(wǎng)卡上打開一個socket,因為這是一個具有危險性的操作,所以這個調(diào)用只有具有root權(quán)限的用戶才可完成,假設(shè)那個“sock”包含一個已經(jīng)打開的socket。

本站聲明: 本文章由作者或相關(guān)機構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫毥谦F公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運行,同時企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險,如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機 衛(wèi)星通信

要點: 有效應(yīng)對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅持高質(zhì)量發(fā)展策略,塑強核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運營商 數(shù)字經(jīng)濟

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術(shù)學(xué)會聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(shù)(集團)股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉