Sto lavorando per integrare scapy con twisted, ma mi sono imbattuto in questo strano bug su OSX che non riesco a capire.Raw socket e sendto in python
Fondamentalmente non riesco a inviare un pacchetto TCP valido (comprensivo di intestazioni IP) tramite un socket non elaborato. Questo è quello che sto facendo:
import socket
from scapy.all import IP, TCP
pkt = IP(src='0.0.0.0', dst='127.0.0.1')/TCP()
spkt1 = str(pkt)
outs = socket.socket(socket.AF_INET, socket.SOCK_RAW, socket.IPPROTO_RAW)
outs.setsockopt(socket.SOL_IP, socket.IP_HDRINCL, 1)
outs.sendto(spkt1, ('127.0.0.1', 0))
Quando ho eseguito questo ricevo il seguente errore:
outs.sendto(spkt1, ('127.0.0.1', 0)) socket.error: [Errno 22] Invalid argument
Nel caso in cui non si dispone di Scapy sulla non vogliono usarlo in questo è il base64 pacchetti codificati:
import base64
spkt1 = base64.b64decode("RQAAKAABAABABvvOAAAAAH8AAAEAFABQAAAAAAAAAABQAiAAEH4AAA==")
La cosa strana è che un pacchetto che è quasi identico sembra essere stato inviato correttamente:
spkt2 = base64.b64decode("RQBAAAWwAAACBgAAAAAAAH8AAAEAyAOEAAAAAAAAAACwAgDIAHsAAAIEBbQBAwMBAQEICk3PUjMAAAAABAIAAA==")
Ecco come i due pacchetti assomigliano:
SPKT1
0000 45 00 00 28 00 01 00 00 40 06 FB CE 00 00 00 00 E..([email protected]
0010 7F 00 00 01 00 14 00 50 00 00 00 00 00 00 00 00 .......P........
0020 50 02 20 00 10 7E 00 00 P. ..~..
SPKT2
0000 45 00 40 00 05 B0 00 00 02 06 00 00 00 00 00 00 [email protected]
0010 7F 00 00 01 00 C8 03 84 00 00 00 00 00 00 00 00 ................
0020 B0 02 00 C8 00 7B 00 00 02 04 05 B4 01 03 03 01 .....{..........
0030 01 01 08 0A 4D CF 52 33 00 00 00 00 04 02 00 00 ....M.R3........
Con loro check-out in Wireshark differiscono solo nella parte TCP.
Ho eseguito molti esperimenti diversi e alla fine sono riuscito a impostare determinate opzioni TCP specifiche per ottenere il pacchetto inviato, ma non ha senso che un tale pacchetto non funzioni.
Qualcuno ha un'idea del motivo per cui ciò potrebbe accadere?
EDIT:
viene visualizzato questo pacchetto a lavorare:
pkt = IP(len=16384, src='0.0.0.0', dst='127.0.0.1',
id=RandShort(), ttl=2)/TCP(sport=255,
dport=900, flags="S", window=200,
options=[('MSS', 1460), ('WScale', 2)])
spkt = bytes(pkt)
spkt += '\x00'*20
Se non si aggiungono gli zeri non funziona.
Puoi correggere l'importazione nel tuo primo frammento di codice? (anche, fatto divertente mentre leggo la richiesta della tua domanda: puoi usare '" ... ".decode (" base64 ")' e '" ... ".encode (" base64 ")' invece di 'import base64') . Ok, mi dispiace, non posso aiutare con questo. Ma tu hai il mio upvote. –
sì, risolto l'importazione. –
FWIW, sto ricevendo lo stesso errore sul tuo codice. –