VB.NET获取MAC地址

方法一:nbtstat 命令

Public Function GetMac(ByVal IP As String) As String

       Try

            '定义输出变量。

            Dim StrMac As String = String.Empty

            Dim Str As String = String.Empty

            '定义进程参数。

            Dim Info As New ProcessStartInfo

            Info.FileName = "nbtstat"

            Info.Arguments = "-a " + IP

            Info.UseShellExecute = False

            Info.RedirectStandardInput = False

            Info.RedirectStandardOutput = True

            Info.RedirectStandardError = True

            Info.CreateNoWindow = True

            Info.WindowStyle = ProcessWindowStyle.Hidden

            '定义新进程。

            Dim mProcess As New Process

            '开始执行操作。

            mProcess = Process.Start(Info)

            '无限循环按行读取输出内容。

            While True

                '读取一行数据。

                Str = mProcess.StandardOutput.ReadLine()

                mProcess.WaitForExit()

                StrMac = Str.Trim()

                '判断是否有 Mac Address字眼。

                If StrMac.ToLower.Contains("mac address") Then

                    Exit While

                Else

                    If StrMac.ToLower.Contains("host not found") Then

                        Exit While

                    End If

                End If

            End While

            '返回值。

            Return StrMac

        Catch ex As Exception

            '返回错误值。

            Return String.Format("Get Error. 原因:{0}", ex.Message)

        End Try

 

方法2:SendARP 函数

Private Declare Ansi Function SendARP Lib "Iphlpapi.dll" (ByVal dest As Int32, ByVal host As Int32, ByRef mac As Int64, ByRef length As Int32) As Int32

    Private Declare Ansi Function inet_addr Lib "Ws2_32.dll" (ByVal IP As String) As Int32

    Public Function getRemoteMAC(ByVal RemoteIp As String) As String

        Dim Dest As Int32 = inet_addr(RemoteIp)

        Dim Str As String = String.Empty

        Dim StrMac As String = String.Empty

        Try

            Dim MacInfo As New Int64

            Dim Len As Int32 = 6

            Dim Res As Integer = SendARP(Dest, 0, MacInfo, Len)

            Str = Convert.ToString(MacInfo, 16).ToUpper

            If Str.Length = 12 Then

                '因为取出来的值是反的,所以要处理下。

                Dim M(5) As String

                M(0) = Str.Substring(10, 2)

                M(1) = Str.Substring(8, 2)

                M(2) = Str.Substring(6, 2)

                M(3) = Str.Substring(4, 2)

                M(4) = Str.Substring(2, 2)

                M(5) = Str.Substring(0, 2)

                StrMac = String.Format("{0}-{1}-{2}-{3}-{4}-{5}", M(0), M(1), M(2), M(3), M(4), M(5))

            Else

                StrMac = "Host not found."

            End If

        Catch ex As Exception

            '返回错误值。

            Return String.Format("Get Error. 原因:{0}", ex.Message)

        End Try

        Return StrMac

    End Function

 

方法3:用WMI,先工程-引用 Microsoft WMI Scripting V1.1 Library

Private Sub wmiSoundDeviceInfo()

 

        Dim wmiObjSet As WbemScripting.SWbemObjectSet

        Dim obj As SWbemObject

 

        wmiObjSet = GetObject("winmgmts:{impersonationLevel=impersonate}"). _

        InstancesOf("Win32_NetworkAdapterConfiguration")

        For Each obj In wmiObjSet

            Debug.Print(obj.MACAddress)

        Next

    End Sub

 方法4:

Imports System.Net.NetworkInformation

Function getMacAddress()

        Dim nics() As NetworkInterface = _

              NetworkInterface.GetAllNetworkInterfaces

        Return nics(0).GetPhysicalAddress.ToString

    End Function

 

  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值