2010-11-03 14 views
5

Witajcie, Szukałem w Internecie rozwiązania, ale niczego nie znalazłem! :(Uzyskaj zdalny adres MAC poprzez IPv6

Czy możliwe jest uzyskanie MAC z innego komputera w tej samej sieci przez IPv6 (bez WMI)? Z IPv4 jest to łatwe (ARP) IPv6 używa "Neighbor Discovery Protocol (NDP) do uzyskać adres MAC. Czy są jakieś metody w .NET do tego?

wszelkie sugestie? dzięki za pomoc!

Pozdrowienia

Fabian

+0

Jaki jest sens tagu OSX tutaj? pytanie i przyjęta odpowiedź wyglądają zupełnie nieistotnie dla OSX ... – ivan

Odpowiedz

3

można uruchomić polecenie zewnętrzne „Ne tsh int ipv6 show neigh ", i odfiltruj hosta, który cię interesuje. Powinieneś skontaktować się z nim tuż przed tym, więc wiesz, że jest w NC.

Jeśli potrzebujesz API do tego, użyj GetIpNetTable2 lub, bardziej bezpośrednio, ResolveIpNetEntry2. Wątpię, czy jest do tego API .NET, więc będziesz musiał użyć PInvoke.

+0

Dziękuję. Myślę, że powinno to rozwiązać mój problem. Próbowałem, ale nie jest to łatwe, aby działało w 5 minut;). Jeśli mam wynik, ponownie się kontaktuję – Fabian

2

Odpowiedź Martina dotyczyła Windowsa, ale jest tak, jeśli używasz GNU/Linuksa lub innego * nix-a.

Chcesz skorzystać z funkcji neigh dowodzenia w ip pokazać sąsiadów IPv6, tak:

$ ip -6 neigh 
fe80::200:ff:fe00:0 dev eth0 lladdr 00:0e:54:24:23:21 router REACHABLE 
fe80::202:b0ff:fe01:2abe dev eth0 lladdr 00:02:b0:02:2a:be DELAY 

(Pro wskazówka: można pozostawić -6 off i zobaczyć IPv4 ARP, jak i IPv6 ND w ta sama lista).

Ponadto, jeśli chcesz dowiedzieć się adresy MAC wszystkie maszyn IPv6 w sieci lokalnej, a nie tylko te, które już wiedzą o, należy ping je najpierw, a następnie szukać dla ne ighbours:

$ ping6 ff02::1%eth0 
64 bytes from fe80::221:84ff:fe42:86ef: icmp_seq=1 ttl=64 time=0.053 ms # <-- you 
64 bytes from fe80::200:ff:fe00:0: icmp_seq=1 ttl=64 time=2.37 ms (DUP!) 
64 bytes from fe80::202:b0ff:fe01:2abe: icmp_seq=1 ttl=64 time=2.38 ms (DUP!) 
64 bytes from fe80::215:abff:fe63:f6fa: icmp_seq=1 ttl=64 time=2.66 ms (DUP!) 

$ ip -6 neigh 
fe80::200:ff:fe00:0 dev eth0 lladdr 00:0e:54:24:23:21 router REACHABLE 
fe80::202:b0ff:fe01:2abe dev eth0 lladdr 00:02:b0:02:2a:be DELAY 
fe80::215:abff:fe63:f6fa dev eth0 lladdr 00:02:15:ab:f6:fa DELAY # <-- a new one! 
+0

Dziękuję za odpowiedź. Chociaż nie pasuje całkowicie, ponieważ pracuję w C# i .Net. Ale mimo to mi pomogła. – Fabian

-1

Oto mój kod:

public static string netsh(String IPv6) 
     { 
      Process p = new Process(); 
      p.StartInfo.FileName = "netsh.exe"; 
      String command = "int ipv6 show neigh"; 
      Console.WriteLine(command); 
      p.StartInfo.Arguments = command; 
      p.StartInfo.UseShellExecute = false; 
      p.StartInfo.RedirectStandardOutput = true; 
      p.Start(); 

      String output = "go"; 
      while (output!=null){ 
      try 
      { 
       output = p.StandardOutput.ReadLine(); 
      } 
      catch (Exception) 
      { 
       output = null; 
      } 
      if (output.Contains(IPv6)) 
      { 
       // Nimmt die Zeile in der sich die IPv6 Addresse und die MAC Addresse des Clients befindet 
       // Löscht den IPv6 Eintrag, entfernt alle Leerzeichen und kürzt den String auf 17 Zeichen, So erschein die MacAddresse im Format "33-33-ff-0d-57-00" 

       output = output.Replace(IPv6, "").Replace(" ", "").TrimToMaxLength(17) ; 
       return output; 
      } 
      } 
      return null; 

     } 
+0

Dlaczego upadek? –

+0

Podejrzewam, że głosowanie w dół było, ponieważ jest to bardzo delikatny kod parsujący. Jeśli argument IPv6 znajduje się w innym przypadku niż wynik polecenia netsh, zakończy się niepowodzeniem. Jeśli argument IPv6 jest całkowicie poprawny i poprawny, ale robi inny wybór na prowadzących zero lub zwiniętych polach zerowych, to zawiedzie. Jeśli argument IPv6 jest podzbiorem tego, co dzieje się w linii, daje fałszywie dodatnie dopasowanie. –

0

Odpowiedź przez @Alex byłoby lepiej, gdyby linia analizowania kodu zostały ulepszone. Oto jeden sposób:

public static string netsh(String IPv6) 
{ 
    IPAddress wanted; 
    if (!IPAddress.TryParse(IPv6, out wanted)) 
     throw new ArgumentException("Can't parse as an IPAddress", "IPv6"); 

    Regex re = new Regex("^([0-9A-F]\S+)\s+(\S+)\s+(\S+)", RegexOptions.IgnoreCase); 

    // ... the code that runs netsh and gathers the output. 

     Match m = re.Match(output); 
     if (m.Success) 
     { 
      // [0] is the entire line 
      // [1] is the IP Address string 
      // [2] is the MAC Address string 
      // [3] is the status (Permanent, Stale, ...) 
      // 
      IPAddress found; 
      if (IPAddress.TryParse(m.Groups[1].Value, out found)) 
      { 
       if(wanted.Equals(found)) 
       { 
         return m.Groups[2].Value; 
       } 
      } 
     } 

    // ... the code that finishes the loop on netsh output and returns failure 
}