Vorrei creare pacchetti TCP custome usando gopacket e quindi inviare utilizzando socket raw.Come utilizzare Golang per comporre pacchetti TCP non elaborati (usando gopacket) e inviarli tramite socket raw
Ecco un esempio breve e leggibile andare programma che dimostra quello che mi piacerebbe fare:
package main
import (
"code.google.com/p/gopacket"
"code.google.com/p/gopacket/examples/util"
"code.google.com/p/gopacket/layers"
"log"
"net"
)
func main() {
defer util.Run()()
// XXX create tcp/ip packet
srcIP := net.ParseIP("127.0.0.1")
dstIP := net.ParseIP("192.168.0.1")
//srcIPaddr := net.IPAddr{
// IP: srcIP,
//}
dstIPaddr := net.IPAddr{
IP: dstIP,
}
ipLayer := layers.IPv4{
SrcIP: srcIP,
DstIP: dstIP,
Protocol: layers.IPProtocolTCP,
}
tcpLayer := layers.TCP{
SrcPort: layers.TCPPort(666),
DstPort: layers.TCPPort(22),
SYN: true,
}
tcpLayer.SetNetworkLayerForChecksum(&ipLayer)
buf := gopacket.NewSerializeBuffer()
opts := gopacket.SerializeOptions{
FixLengths: true,
ComputeChecksums: true,
}
err := gopacket.SerializeLayers(buf, opts, &ipLayer, &tcpLayer)
if err != nil {
panic(err)
}
// XXX end of packet creation
// XXX send packet
ipConn, err := net.ListenPacket("ip4:tcp", "0.0.0.0")
if err != nil {
panic(err)
}
_, err = ipConn.WriteTo(buf.Bytes(), &dstIPaddr)
if err != nil {
panic(err)
}
log.Print("packet sent!\n")
}
Tuttavia l'esecuzione di questo programma non funziona ... il SerializeLayer fallisce. Ecco il panico:
panico: 127.0.0.1 IP non valido src
goroutine 16 [esecuzione]: runtime.panic (0x5bb020, 0xc2090723e0) /home/uomo/golang-empire/go/src /pkg/runtime/panic.c:279 + 0xf5 main.main() /home/human/golang-empire/gopkg/src/github.com/david415/HoneyBadger/packetSendTest.go:41 + 0x464
goroutine 19 [finalizzatore wait]: runtime.park (0x413cc0, 0x7bc6c0, 0x7bb189) /home/human/golang-empire/go/src/pkg/runtime/proc.c:13 69 + 0x89 runtime.parkunlock (0x7bc6c0, 0x7bb189) /home/human/golang-empire/go/src/pkg/runtime/proc.c:1385 + 0x3b runfinq() /home/umano/golang-impero/vai /src/pkg/runtime/mgc0.c:2644 + 0xcf runtime.goexit() /home/human/golang-empire/go/src/pkg/runtime/proc.c:1445
OK ... Ho corretto l'errore "src ip non valido" ... era dovuto a ParseIP che restituiva il tipo sbagliato ... doveva essere convertito con il suo metodo .To4() ;-) –
Attualmente il mio semplice un esempio conciso è l'invio del pacchetto TCP/IP predisposto ... tuttavia i numeri di porta e le altre sezioni non sono corretti. Forse le "endianità" delle porte TCP sono impostate in modo errato? Semplice esempio conciso qui: https://github.com/david415/HoneyBadger/blob/bd81a0132a2ccd880eee210acf2c965a37b457e3/packetSendTest.go –
Questo nuovo commit dimostra che il pacchetto TCP/IP risultante non è corretto confrontando srcPort e dstPort con i valori previsti dopo il pacchetto dissezione: https://github.com/david415/HoneyBadger/blob/c136e5cd58dddfdd5b97b7c4b65e338f41d0b09d/packetSendTest.go –