来到编程网的大家,相信都是编程学习爱好者,希望在这里学习Golang相关编程知识。下面本篇文章就来带大家聊聊《发送 EAPoL 数据包:请求身份》,介绍一下,希望对大家的知识积累有所帮助,助力实战开发!
问题内容我尝试发送请求身份 eapol 数据包:
func eapol_requestIdentity(handle *pcap.Handle, iface *net.Interface, id uint8) error {
len := uint16(5) // eap1 field length
eap1 := layers.EAP{
Code: layers.EAPCodeResponse,
Id: id,
Type: layers.EAPTypeIdentity,
TypeData: []byte{byte(layers.EAPTypeIdentity)}, // bugfix
Length: len,
}
eapol := layers.EAPOL{
Version: 1,
Type: layers.EAPOLTypeEAP,
Length: eap1.Length,
}
eth := layers.Ethernet{
SrcMAC: iface.HardwareAddr,
DstMAC: net.HardwareAddr{0x01, 0x80, 0xc2, 0x00, 0x00, 0x03},
EthernetType: layers.EthernetTypeEAPOL,
}
buf := gopacket.NewSerializeBuffer()
opts := gopacket.SerializeOptions{
//FixLengths: true, // doesn't work
FixLengths: false,
ComputeChecksums: true,
}
gopacket.SerializeLayers(buf, opts, ð, &eapol, &eap1)
log.Printf("send EOPoL : Request Identity %u...", id)
if err := handle.WritePacketData(buf.Bytes()); err != nil {
log.Printf("Send err ", err)
return err
}
log.Printf("send packet [OK]")
return nil
}
我不明白:如果我删除行 typedata: [] byte{byte(layers.eaptypeidentity)}
或行 type:layers.eaptypeidentity
,我的应用程序发送了错误的数据包。
这正常吗?...为什么我必须为数据包中的同一字节设置两次数据?
此外,我尝试将 fixlengths 设置为 true,但发送的数据包中的长度字段是错误的...
正确答案
我对eap
不是很熟悉,但是根据RFC,type
和type-data
是两个不同的字段:
0 1 2 3
0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
| code | identifier | length |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
| type | type-data ...
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-
因此,按理说,如果您遗漏了数据包的一部分,那么它就是“错误的”。
关于长度,gopacket在计算长度时似乎有一个bug。根据RFC
长度字段是两个八位字节,表示eap的长度 数据包包括代码、标识符、长度、类型和类型数据 字段
但是当fixlengths
是true
时,gopacket only counts Type
and Type-Data
。
if opts.FixLengths {
e.Length = uint16(len(e.TypeData) + 1)
}
+1
应该是 +5
,所以看来您发现了一个错误。
编辑:看来您已经填写了错误报告:https://github.com/google/gopacket/issues/931
今天关于《发送 EAPoL 数据包:请求身份》的内容就介绍到这里了,是不是学起来一目了然!想要了解更多关于的内容请关注编程网公众号!