Golang案例开发之gopacket抓包入门(1)

文章目录


前言

说起网络抓包,我们一定听过大名鼎鼎的Tcpdump和WireShark。他们分别是Linux平台和Windows平台的抓包工具。

Wireshark抓包工具,其底层抓包库是npcap(以前是winpcap);

Tcpdump,其抓包库是libpcap;


一、gopacket是什么?

gopacket库可以说是libpcap和npcap的go封装,提供了更方便的go语言操作接口。

项目地址:项目地址

项目文档:项目文档

二、gopacket前提

在使用gopacket包时,首先要确保在windows平台下安装了npcap或winpcap,或者是在linux平台下安装了libpcap库。

npcap下载地址:https://nmap.org/npcap/

libpcap下载地址:https://www.tcpdump.org/

下载自己电脑对应的操作系统版本的库

我们本次是在Centos操作系统下进行。

安装libpcap

bash 复制代码
# yum 安装
yum install libpcap libpcap-devel

# 查看安装
rpm -qa | grep libpcap

安装gopacket

bash 复制代码
go get github.com/google/gopacket

二、实践 枚举主机上网络设备的接口

1、代码

代码如下(示例):

go 复制代码
package main

import (
	"fmt"
	"log"

	"github.com/google/gopacket/pcap"
)

func main() {
	devices, err := pcap.FindAllDevs()
	if err != nil {
		log.Fatal(err)
	}
	for _, device := range devices {
		// fmt.Printf("Device: %v ", device)
		fmt.Printf("Device NAME: %v \n", device.Name)
		// fmt.Printf("Device Description: %v \n", device.Description)
		// fmt.Printf("Device Flags: %v \n", device.Flags)
		// fmt.Printf("Device Addresses: %v \n", device.Addresses)
		for _, address := range device.Addresses {
			fmt.Printf("IP NAME: %v \n", address.IP)
		}
	}
}

2、结果

代码如下(示例):

bash 复制代码
[root@work gopacket]# go run day01/main.go 
Device NAME: docker0 
IP NAME: 172.17.0.1 
Device NAME: nflog 
Device NAME: nfqueue 
Device NAME: usbmon1 
Device NAME: usbmon2 
Device NAME: ens33 
IP NAME: 192.168.37.100 
IP NAME: fe80::28eb:debf:57bc:2980 
Device NAME: any 
Device NAME: lo 
IP NAME: 127.0.0.1 
IP NAME: ::1 

文档

我们可以打开gopacket下面的pcap查看具体的定义:
pcap


总结

本节,主要是搭建下开发环境,尝试获取网络设备的接口。下一节,尝试在一个网络设备上抓包。

相关推荐
aini_lovee几秒前
MATLAB基于小波技术的图像融合实现
开发语言·人工智能·matlab
郝学胜-神的一滴4 分钟前
深入解析C/S模型下的TCP通信流程:从握手到挥手的技术之旅
linux·服务器·c语言·网络·网络协议·tcp/ip
池央9 分钟前
CANN 算子诊断与故障定位:oam-tools 在异构计算错误解析中的作用
网络
“αβ”12 分钟前
数据链路层协议 -- 以太网协议与ARP协议
服务器·网络·网络协议·以太网·数据链路层·arp·mac地址
R1nG86313 分钟前
多线程安全设计 CANN Runtime关键数据结构的锁优化
开发语言·cann
初次见面我叫泰隆14 分钟前
Qt——5、Qt系统相关
开发语言·qt·客户端开发
释怀不想释怀18 分钟前
Linux网络基础(ip,域名)
linux·网络·tcp/ip
亓才孓19 分钟前
[Class的应用]获取类的信息
java·开发语言
开开心心就好27 分钟前
AI人声伴奏分离工具,离线提取伴奏K歌用
java·linux·开发语言·网络·人工智能·电脑·blender
子榆.30 分钟前
CANN 性能分析与调优实战:使用 msprof 定位瓶颈,榨干硬件每一分算力
大数据·网络·人工智能