michaz
Goto Top

Wie kann man mit VBS eine MAC Adresse in eine Var schreiben?

Hallo Leute...

suche eine einfache Möglichkeit per VBS die Lokale MAC des Hosts in eine Variable zu schreiben...

mfg
michA

Content-Key: 66242

Url: https://administrator.de/contentid/66242

Ausgedruckt am: 28.03.2024 um 14:03 Uhr

Mitglied: gemini
gemini 15.08.2007 um 10:22:18 Uhr
Goto Top
Hallo MichaZ,

Option Explicit
Dim objWMIService, colAdapters, objAdapter, strMAC, strComputer
strComputer = "."  
Set objWMIService = GetObject("winmgmts:" _  
    & "{impersonationLevel=impersonate}!\\" & strComputer & "\root\cimv2")  
Set colAdapters = objWMIService.ExecQuery _
    ("SELECT * FROM Win32_NetworkAdapterConfiguration WHERE IPEnabled = True")  
For Each objAdapter in colAdapters
   strMAC = objAdapter.MACAddress
MsgBox strMAC
Next
Wenn mehrere Netzwerkkarten aktiv sind, wird strMAC jeweils überschrieben.
In solch einem Fall könntest du WHERE entspr. einschränken, je nachdem welche Informationen der Konfiguration dir vorliegen. Bspw.
WHERE IPAddress = aaa.bbb.ccc.ddd
WHERE Caption = xxxxxxxxxxxx
WHERE Description = xxxxxxxxxxx

HTH,
gemini
Mitglied: MichaZ
MichaZ 15.08.2007 um 11:18:02 Uhr
Goto Top
Hallo "gemini

Danke erst mal für die Hilfe

naja es sollte immer die erste Karte sein

also müsste man dann mit WHERE Description = LAN-Verbindung
arbeiten ?!?!
Mitglied: gemini
gemini 15.08.2007 um 11:55:39 Uhr
Goto Top
Hi,

teste doch einfach, was zurückgegeben wird.

Wenn nur eine Karte eingebaut ist, onboard- und virtuelle Karten (Cisco-Client, VMware etc.) zählen hier mit, kann WHERE ... auch ganz weggelassen werden.

Gruß,
gemini
Mitglied: MichaZ
MichaZ 15.08.2007 um 13:56:56 Uhr
Goto Top
er gibt alle MAC's der Reihe nach zurück...

muss mal schaun ob das etwas ausmacht...
brauche den Wert der ersten für eine SQL-Abfrage...
aber da bastel ich gerade noch dran... das klappt noch nich..
Mitglied: bastla
bastla 15.08.2007 um 18:30:19 Uhr
Goto Top
Hallo MichaZ!

Wenn's nur der erste Wert sein soll, könntest Du ja einfach
strMAC = objAdapter.MACAddress
durch
If strMAC = "" Then strMAC = objAdapter.MACAddress  
ersetzen ...

Grüße
bastla
Mitglied: MichaZ
MichaZ 16.08.2007 um 08:17:42 Uhr
Goto Top
Danke bastla für die Hilfe...

kannst du mir das vielleicht noch kurz erklären wie das ganze funst???

mfg
michA
Mitglied: bastla
bastla 17.08.2007 um 21:41:12 Uhr
Goto Top
Hallo MichaZ!

Das "Ganze" ist in erster Linie eine WMI-Abfrage (schau Dir dazu einmal WMI Code Creator oder Scriptomatic und für den Background zB die msdn WMI Reference an), welche eine Collection (Aufzählung) liefert - in diesem Fall eben alle "NetworkAdapter". Mit einer "For Each"-Schleife kannst Du die alle durchgehen und die gewünschte(n) Eigenschafte(n) - im konkreten Fall etwa "MACAddress" - jedes Elements auslesen.

Da Du nur vom ersten Element den Wert mitnehmen wolltest, prüft meine "If"-Zeile einfach, ob schon eine MAC-Adresse in der Variablen "strMAC" steht und nur, wenn noch keine da ist, wird die Adresse des aktuellen Elements in die Variable geschrieben. Ohne diese Prüfung (und ohne Verwendung eines Arrays) würde bei jedem Schleifendurchlauf der Variableninhalt neu gesetzt, so dass am Schluss eben die letzte gefundene MAC-Adresse gespeichert wäre.

Zumeist wird es aber sinnvoller sein, wie von gemini vorgeschlagen, entweder bei der WMI-Abfrage schon eine Bedingung einzubauen oder in der Auswertungsschleife noch eine andere Eigenschaft, etwa "Caption", abzufragen, sodass Du Dich nicht auf die Reihenfolge verlassen musst. Ein Beispiel (für die zweite Möglichkeit) könnte so aussehen:
If InStr(1, objAdapter.Caption, "Broadcom", vbTextCompare) > 0 Then strMAC = objAdapter.MACAddress  
Damit würden nur Netzwerkgeräte mit einer Bezeichnung, die "Broadcom" enthält (das "vbTextCompare" sorgt dafür, dass Groß- und Kleinschreibung keine Rolle spielt), berücksichtigt werden.

Grüße
bastla