ngrep 是grep的網(wǎng)絡(luò)版,他力求更多的grep特征,用于搜尋指定的數(shù)據(jù)包。由于安裝ngrep需用到ibpcap庫(kù), 所以支持大量的操作系統(tǒng)和網(wǎng)絡(luò)協(xié)議,能識(shí)別TCP、UDP和ICMP包。
安裝ngrep
下載地址
git clone git://git.code.sf.net/p/ngrep/code ngrep-code
進(jìn)入目錄
cd ngrep-code
./configure --with-pcap-includes=/usr/local/include/pcap
make
make install
選項(xiàng)
-h is help/usage
-V is version information
-q is be quiet (don't print packet reception hash marks)靜默模式,如果沒(méi)有此開(kāi)關(guān),未匹配的數(shù)據(jù)包都以“#”顯示
-e is show empty packets 顯示空數(shù)據(jù)包
-i is ignore case 忽略大小寫(xiě)
-v is invert match 反轉(zhuǎn)匹配
-R is don't do privilege revocation logic
-x is print in alternate hexdump format 以16進(jìn)制格式顯示
-X is interpret match expression as hexadecimal 以16進(jìn)制格式匹配
-w is word-regex (expression must match as a word) 整字匹配
-p is don't go into promiscuous mode 不使用混雜模式
-l is make stdout line buffered
-D is replay pcap_dumps with their recorded time intervals
-t is print timestamp every time a packet is matched在每個(gè)匹配的包之前顯示時(shí)間戳
-T is print delta timestamp every time a packet is matched顯示上一個(gè)匹配的數(shù)據(jù)包之間的時(shí)間間隔
-M is don't do multi-line match (do single-line match instead)僅進(jìn)行單行匹配
-I is read packet stream from pcap format file pcap_dump 從文件中讀取數(shù)據(jù)進(jìn)行匹配
-O is dump matched packets in pcap format to pcap_dump 將匹配的數(shù)據(jù)保存到文件
-n is look at only num packets 僅捕獲指定數(shù)目的數(shù)據(jù)包進(jìn)行查看
-A is dump num packets after a match匹配到數(shù)據(jù)包后Dump隨后的指定數(shù)目的數(shù)據(jù)包
-s is set the bpf caplen
-S is set the limitlen on matched packets
-W is set the dump format (normal, byline, single, none) 設(shè)置顯示格式byline將解析包中的換行符
-c is force the column width to the specified size 強(qiáng)制顯示列的寬度
-P is set the non-printable display char to what is specified
-F is read the bpf filter from the specified file 使用文件中定義的bpf(Berkeley Packet Filter)
-N is show sub protocol number 顯示由IANA定義的子協(xié)議號(hào)
-d is use specified device (index) instead of the pcap default
應(yīng)用舉例:
捕獲所有post請(qǐng)求(加個(gè)-W byline 參數(shù)后,將解析包中的換行符):
ranger@ranger:~$ sudo ngrep -q -W byline "(POST).*"
interface: eth0 (192.168.122.0/255.255.254.0)
match: (POST).*
T 192.168.122.74:46048 -> 140.207.228.58:80 [A]
POST /Hotel/OTA_HotelSearch.asmx?wsdl HTTP/1.1.
Content-Type: text/xml; charset=UTF-8.
SOAPAction: http://ctrip.com/Request.
Accept-Encoding: gzip, deflate.
Content-Length: 1330.
Accept: */*.
Accept-Language: zh-cn.
User-Agent: Mozilla/4.0 (compatible; MSIE 8.0; Windows NT 5.1; Trident/4.0).
UA-CPU: x86.
Accept-Encoding: gzip, deflate.
Connection: close.
Host: openapi.ctrip.com.
.
?xml version="1.0" encoding="utf-8"?>soap:Envelope xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/"> soap:Body> Request xmlns="http://ctrip.com/"> requestXML>lt;Requestgt;
lt;Header AllianceID="***" SID="***" TimeStamp="1393554304685" RequestType="OTA_HotelSearch" Signature="B166CDF5422A6DA5BA81A08036E938E7"/gt;
lt;HotelRequestgt;
lt;RequestBody xmlns:ns="http://www.opentravel.org/OTA/2003/05" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:xsd="http://www.w3.org/2001/XMLSchema"gt;
lt;ns:OTA_HotelSearchRQ Version="1.0" PrimaryLangID="zh"
xsi:schemaLocation="http://www.opentravel.org/OTA/2003/05 OTA_HotelSearchRQ.xsd"