Windows和Linux下使用Gopacket監(jiān)控網(wǎng)卡流量

一.獲取gopacket

go get  github.com/google/gopacket

二.編譯

1.windows

直接編譯即可

2.linux

不能從windows下交叉編譯到linux衬衬,(安裝了MINGW也不行)买猖,所以需要在linux上編譯。
編譯前準(zhǔn)備:(Centos示例)

yum -y install gcc
yum -y install gcc-c++
yum -y install libpcap
yum -y install libpcap-devel

三.示例代碼

var ListenNetwork  = "Adapter for loopback traffic capture"http://監(jiān)聽的網(wǎng)卡
var ListenPort  ="80"http://監(jiān)聽的端口

func main()  {
    ptrListenNetwork:= flag.String("i","eth0","監(jiān)聽的網(wǎng)卡")
    ptrListenPort:=flag.String("p","80","監(jiān)聽的端口")
    flag.Parse()
    ListenNetwork=*ptrListenNetwork
    ListenPort=*ptrListenPort
    var deviceTarget=""
    devices, err := pcap.FindAllDevs()
    if err!=nil{
        panic(err.Error())
    }
    for _,v:=range devices{
        fmt.Println(v.Name,v.Description)
        if v.Description==ListenNetwork{//win10 這里用Description來判斷網(wǎng)卡滋尉,主要是Name太亂了
            deviceTarget=v.Name
            break
        }
        if v.Name==ListenNetwork{//linux
            deviceTarget=v.Name
            break
        }
    }
    signalChan := make(chan os.Signal, 1)
    signal.Notify(signalChan, syscall.SIGHUP, syscall.SIGINT, syscall.SIGKILL)
    ctx, cancel := context.WithCancel(context.Background())
    if deviceTarget!=""{
        go listenPacket(deviceTarget,ctx)
        for {
            select {
            case <-signalChan:
                cancel()
                return
            }
        }
    }
}

func listenPacket(iface string, ctx context.Context) {
    handle,err:=pcap.OpenLive(iface,65536,true,-time.Millisecond * 10)
    if err!=nil{
        fmt.Println(err.Error())
        return
    }
    defer handle.Close()
    err=handle.SetBPFFilter(fmt.Sprintf("(src port %s) or (dst port %s)",listenPort,listenPort))
    if err!=nil{
        fmt.Println(err.Error())
        return
    }
    ps := gopacket.NewPacketSource(handle, handle.LinkType())
    var rxLen int64
    var txLen int64
    var packId int64
    fmt.Println(fmt.Sprintf("listen device:%s,port:%s",iface,ListenPort))
    for {
        select {
        case <-ctx.Done():
            return
        case p := <-ps.Packets():
            //fmt.Println(p.Metadata().CaptureInfo.Timestamp,p.Metadata().CaptureInfo.Length)
            //fmt.Println(p.NetworkLayer().NetworkFlow().String())
            //fmt.Println(p.TransportLayer().TransportFlow().Endpoints())
            srcEndpoint,dstEndpoint:=p.TransportLayer().TransportFlow().Endpoints()
            srcPort,dstPort:=srcEndpoint.String(),dstEndpoint.String()
            flag1:=false
            if srcPort==ListenPort{
                packId++
                flag1=true
                l:=p.Metadata().Length
                txLen+=int64(l)
                fmt.Println(fmt.Sprintf("PackId:%d,Port:%s send package,len:%d,stats[RX:%d,TX:%d]",packId,ListenPort,l,rxLen,txLen))
            }
            if dstPort==ListenPort{
                if !flag1{
                    packId++
                }
                l:=p.Metadata().Length
                rxLen+=int64(l)
                fmt.Println(fmt.Sprintf("PackId:%d,Port:%s get package,len:%d,stats[RX:%d,TX:%d]",packId,ListenPort,l,rxLen,txLen))
            }
        }
    }
}

注意事項(xiàng)

linux下編譯的包移植到其它機(jī)器運(yùn)行玉控,仍依賴于libpcap,但是不需要libpcap-devel

yum -y install libpcap
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子惹谐,更是在濱河造成了極大的恐慌,老刑警劉巖虱而,帶你破解...
    沈念sama閱讀 211,290評論 6 491
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異耽梅,居然都是意外死亡薛窥,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,107評論 2 385
  • 文/潘曉璐 我一進(jìn)店門眼姐,熙熙樓的掌柜王于貴愁眉苦臉地迎上來诅迷,“玉大人,你說我怎么就攤上這事众旗“丈迹” “怎么了?”我有些...
    開封第一講書人閱讀 156,872評論 0 347
  • 文/不壞的土叔 我叫張陵贡歧,是天一觀的道長滩租。 經(jīng)常有香客問我,道長利朵,這世上最難降的妖魔是什么律想? 我笑而不...
    開封第一講書人閱讀 56,415評論 1 283
  • 正文 為了忘掉前任,我火速辦了婚禮绍弟,結(jié)果婚禮上技即,老公的妹妹穿的比我還像新娘。我一直安慰自己樟遣,他們只是感情好而叼,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,453評論 6 385
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著豹悬,像睡著了一般葵陵。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上瞻佛,一...
    開封第一講書人閱讀 49,784評論 1 290
  • 那天脱篙,我揣著相機(jī)與錄音,去河邊找鬼。 笑死涡尘,一個(gè)胖子當(dāng)著我的面吹牛忍弛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播考抄,決...
    沈念sama閱讀 38,927評論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼蔗彤!你這毒婦竟也來了川梅?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,691評論 0 266
  • 序言:老撾萬榮一對情侶失蹤然遏,失蹤者是張志新(化名)和其女友劉穎贫途,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體待侵,經(jīng)...
    沈念sama閱讀 44,137評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡丢早,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,472評論 2 326
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了秧倾。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片怨酝。...
    茶點(diǎn)故事閱讀 38,622評論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖那先,靈堂內(nèi)的尸體忽然破棺而出农猬,到底是詐尸還是另有隱情,我是刑警寧澤售淡,帶...
    沈念sama閱讀 34,289評論 4 329
  • 正文 年R本政府宣布斤葱,位于F島的核電站,受9級特大地震影響揖闸,放射性物質(zhì)發(fā)生泄漏揍堕。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,887評論 3 312
  • 文/蒙蒙 一汤纸、第九天 我趴在偏房一處隱蔽的房頂上張望衩茸。 院中可真熱鬧,春花似錦蹲嚣、人聲如沸递瑰。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,741評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽抖部。三九已至,卻和暖如春议惰,著一層夾襖步出監(jiān)牢的瞬間慎颗,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,977評論 1 265
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留俯萎,地道東北人傲宜。 一個(gè)月前我還...
    沈念sama閱讀 46,316評論 2 360
  • 正文 我出身青樓,卻偏偏與公主長得像夫啊,于是被迫代替她去往敵國和親函卒。 傳聞我的和親對象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,490評論 2 348

推薦閱讀更多精彩內(nèi)容