编辑:我将问题扩展到HTTPS。 " S"部分尚未解决,我并不真正需要它,但对其他人来说可能很有趣。
我想做相同的
hdr='GET / HTTP/1.1\r\nContent-Length: 10000000000\r\n\r\n'
(echo -en "$hdr"; dd if=/dev/zero bs=1000000 count=999; read tmp) | nc $SOME_IP 80
使用Python 2.7。如果可能,我只想使用标准库以及requests
和sockets
模块。
仅供参考,上面的脚本会向$SOME_IP
发送一个大的HTTP请求(~1GB的零)而不会对发送者RAM造成沉重的负担。
答案 0 :(得分:0)
这样的东西?
import socket
def get_content_length():
return 10000000000
def get_chunk_size():
return 1000000
def yield_content():
total_size = get_content_length()
chunk_size = get_chunk_size()
current_size = 0
end = total_size - chunk_size
chunk = '\x00' * chunk_size
while current_size < end:
yield chunk
current_size += chunk_size
yield chunk[:total_size - current_size]
s = socket.socket()
s.connect((host, port))
hdr='GET / HTTP/1.1\r\nContent-Length: %s\r\n\r\n' % get_content_length()
s.sendall(hdr)
for chunk in yield_content():
s.sendall(chunk)
# should I wait for the response?
答案 1 :(得分:0)
这是我做的东西,似乎有效:
import sys, socket
def flood(hostname, port, count=1):
s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
s.connect((hostname, port))
s.sendall('GET / HTTP/1.1\r\nContent-Length: 10000000000\r\n\r\n')
with open('/dev/zero', 'rb', ) as data:
for _ in xrange(count):
s.sendall(data.read(1000000))
s.shutdown(socket.SHUT_WR)
while True:
data = s.recv(1024)
if data == "":
break
print("Received:", repr(data))
print("Connection closed.")
s.close()
freakish的答案当然更具有跨平台性,因为它不需要/dev/null