Yai*_* B. 5 python get http scapy
我需要创建 HTTP GET 请求并保存数据响应。我尝试使用这个:
syn = IP(dst=URL) / TCP(dport=80, flags='S')
syn_ack = sr1(syn)
getStr = 'GET / HTTP/1.1\r\nHost: www.google.com\r\n\r\n'
request = IP(dst='www.google.com') / TCP(dport=80, sport=syn_ack[TCP].dport,
seq=syn_ack[TCP].ack, ack=syn_ack[TCP].seq + 1, flags='A') / getStr
reply = sr1(request)
print reply.show()
Run Code Online (Sandbox Code Playgroud)
但是当我打印时,reply我没有看到任何数据响应。此外,当我检查“Wireshark”时,我收到了 SYN、SYN/ACK,但没有收到 ACK。
编辑:
我现在尝试这样做:
# Import scapy
from scapy.all import *
# Print info header
print "[*] ACK-GET example -- Thijs 'Thice' Bosschert, 06-06-2011"
# Prepare GET statement
get='GET / HTTP/1.0\n\n'
# Set up target IP
ip=IP(dst="www.google.com")
# Generate random source port number
port=RandNum(1024,65535)
# Create SYN packet
SYN=ip/TCP(sport=port, dport=80, flags="S", seq=42)
# Send SYN and receive SYN,ACK
print "\n[*] Sending SYN packet"
SYNACK=sr1(SYN)
# Create ACK with GET request
ACK=ip/TCP(sport=SYNACK.dport, dport=80, flags="A", seq=SYNACK.ack, ack=SYNACK.seq + 1) / get
# SEND our ACK-GET request
print "\n[*] Sending ACK-GET packet"
reply,error=sr(ACK)
# print reply from server
print "\n[*] Reply from server:"
print reply.show()
print '\n[*] Done!'
Run Code Online (Sandbox Code Playgroud)
但它从服务器打印我的回复;
0000 IP / TCP 192.168.44.130:23181 > 216.58.208.164:http A / 原始 ==> IP / TCP 216.58.208.164:http > 192.168.44.130:23181 A / 填充 无
我需要基于行的文本数据:text/html。
您正在发送 SYN 并正确接收 SYN_ACK。此时,您应该根据收到的 SYN_ACK 生成并发送 ACK,然后最终传输 HTTP GET 请求。看来您对 TCP 3 次握手机制有些困惑。简而言之,您不应该“获得”ACK,您应该自己生成并发送它。
| 归档时间: |
|
| 查看次数: |
12156 次 |
| 最近记录: |