Frage

Ich bin in einer Umgebung mit vielen Computern, die nicht ordnungsgemäß inventarisiert wurden.Grundsätzlich weiß niemand, welcher IP mit welcher MAC -Adresse und welcher Hostnamen eingeht.Also habe ich Folgendes geschrieben:

# This script goes down the entire IP range and attempts to
# retrieve the Hostname and mac address and outputs them
# into a file. Yay!

require "socket"

TwoOctets = "10.26"

def computer_exists?(computerip)
 system("ping -c 1 -W 1 #{computerip}")
end

def append_to_file(line)
 file   = File.open("output.txt", "a")
 file.puts(line)
 file.close
end


def getInfo(current_ip)
 begin
   if computer_exists?(current_ip)
     arp_output = `arp -v #{current_ip}`
     mac_addr = arp_output.to_s.match(/..:..:..:..:..:../)
     host_name = Socket.gethostbyname(current_ip)
     append_to_file("#{host_name[0]} - #{current_ip} - #{mac_addr}\n")
   end
 rescue SocketError => mySocketError
   append_to_file("unknown - #{current_ip} - #{mac_addr}")
 end
end


(6..8).each do |i|
 case i
   when 6
     for j in (1..190)
       current_ip = "#{TwoOctets}.#{i}.#{j}"
       getInfo(current_ip)
     end
   when 7
     for j in (1..255)
       current_ip = "#{TwoOctets}.#{i}.#{j}"
       getInfo(current_ip)
     end
   when 8
     for j in (1..52)
       current_ip = "#{TwoOctets}.#{i}.#{j}"
       getInfo(current_ip)
     end
 end
end

Alles funktioniert, außer dass kein Reverse-DNS gefunden wird.

Die Beispielausgabe, die ich erhalte, ist diese:

10.26.6.12 - 10.26.6.12 - 00:11:11:9B:13:9F
10.26.6.17 - 10.26.6.17 - 08:00:69:9A:97:C3
10.26.6.18 - 10.26.6.18 - 08:00:69:93:2C:E2

Wenn ich mache nslookup 10.26.6.12 Dann erhalte ich den richtigen umgekehrten DNS, so dass meine Maschine den DNS -Server sieht.

Ich habe versucht Socket.gethostbyname, gethostbyaddr, aber es funktioniert nicht.

Jede Anleitung wird sehr geschätzt.

War es hilfreich?

Lösung

Ich würde es mir ansehen getaddrinfo.Wenn Sie die Zeile ersetzen:

host_name = Socket.gethostbyname(current_ip)

mit:

host_name = Socket.getaddrinfo(current_ip, 0, Socket::AF_UNSPEC, Socket::SOCK_STREAM, nil, Socket::AI_CANONNAME)[0][1]

Der getaddrinfo Die Funktion gibt ein Array von Arrays zurück.Mehr dazu können Sie hier lesen:

Ruby Socket-Dokumente

Andere Tipps

Heute brauchte ich auch eine Reverse-DNS-Suche und habe eine sehr einfache Standardlösung gefunden:

require 'resolv'
host_name = Resolv.getname(ip_address_here)

Es scheint, dass es eine Zeitüberschreitung verwendet, die in schwierigen Fällen hilfreich ist.

Das funktioniert auch:

host_name = Socket.getaddrinfo(current_ip,nil)
append_to_file("#{host_name[0][2]} - #{current_ip} - #{mac_addr}\n")

Ich bin mir nicht sicher warum gethostbyaddr hat auch nicht funktioniert.

Lizenziert unter: CC-BY-SA mit Zuschreibung
Nicht verbunden mit StackOverflow
scroll top