使用go语言(net/gopacket)在windows环境下发送伪造源和目的地址的数据包

本文介绍了在Windows系统中尝试使用Go语言的net/gopacket库进行网络嗅探和伪造数据包发送时遇到的难题。尽管gopacket允许从以太层构造数据包,但在Windows下,由于操作系统限制或支持性问题,无法成功发送伪造源和目的地址的UDP/TCP数据包。作者分析了可能的原因并指出在该环境下无法实现此功能。
摘要由CSDN通过智能技术生成

避坑:先说结论--在windows环境下无法通过net/gopacket发送伪造数据包

0x00 背景:

尝试使用go语言在本地网卡嗅探并且过滤,当某个数据包符合预定条件时,在当前网卡上发送伪造的数据包(伪造源地址目的地址,其实就是把抓到的符合条件的包的IP地址、端口进行源目的调换)

0x01 网络嗅探功能:

网络嗅探功能使用gopacket包实现,相对简单,下面是一个基本的例子

package main

import (
    "fmt"
    "log"
    "github.com/google/gopacket"
    "github.com/google/gopacket/pcap"
)

func main() {
    // 设置要嗅探的网络接口
    device := "eth0"

    // 打开网络接口
    handle, err := pcap.OpenLive(device, 65536, true, pcap.BlockForever)
    if err != nil {
        log.Fatal(err)
    }
    defer handle.Close()

    // 创建数据包捕获器
    packetSource := gopacket.NewPacketSource(handle, handle.LinkType())

    // 开始捕获数据包
    for packet := range packetSource.Packets() {
        fmt.Println(packet)
    }
}
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值