还是无论如何,这个函数可以在ruby套接字编程中工作:
conn = pwn.remote('localhost', 4567)
conn.recvuntil("> ")对于原生Ruby模块,socket.read(bytes)将等待直到它接收到确切的字节数,而这一点我无法事先确定。而且,socket.recv(bytes),将在获得一些数据后立即打印,而不管消息是否完成。
因为,我知道消息格式和它的结尾,所以如果有上面提到的gem或者以任何方式获得Ruby中的功能,那就很容易了。
例如,如果我知道来自服务器的消息以冒号结尾,
socket = Socket.new( AF_INET, SOCK_STREAM, 0 )
sockaddr = Socket.pack_sockaddr_in(port, hostname)
socket.connect( sockaddr )
socket.recvuntil ": "
# do something
socket.send "y"发布于 2015-07-23 02:16:11
require 'socket'
def read_until(socket, re)
accu = ''
re = Regexp.escape(re) if String === re
re = /#{re}\Z/
socket.each_char do |c|
accu << c
return accu if re === accu
end
return accu
end
socket = Socket.new(Socket::AF_INET, Socket::SOCK_STREAM, 0 )
sockaddr = Socket.pack_sockaddr_in(80, 'www.google.com')
socket.connect(sockaddr)
socket.write "GET / HTTP/1.0\n\n"
headers = read_until(socket, /\r\n\r\n/)
body = socket.read
puts "HEADERS:\n#{headers}BODY:\n#{body}"https://stackoverflow.com/questions/31576070
复制相似问题