получить локальный IPv4 компьютера с помощью VB.net - PullRequest
6 голосов
/ 29 октября 2009

Я пытаюсь получить IP-адрес моего локального компьютера, и один из моих других компьютеров получает адрес v4 нормально, но на этом коде:

Dns.GetHostEntry(Dns.GetHostName).AddressList(0).ToString()

возвращает, как мне кажется, IPv6-адрес:

fe80::9c09:e2e:4736:4c62%11

Как получить адрес IPv4?

Ответы [ 7 ]

9 голосов
/ 29 октября 2009

Отказ от ответственности - у меня не установлен IPv6, и, вероятно, есть гораздо лучший способ сделать это, но что возвращает следующее:

Dns.GetHostEntry(Dns.GetHostName()).AddressList
    .Where(a => !a.IsIPv6LinkLocal && !a.IsIPv6Multicast && !a.IsIPv6SiteLocal)
    .First()
    .ToString();

Редактировать - не заметил, что вы спрашиваете в VB, поэтому я попытался перевести его на:

Dim s As String = Dns.GetHostEntry(Dns.GetHostName()).AddressList _
    .Where(Function(a As IPAddress) Not a.IsIPv6LinkLocal AndAlso Not a.IsIPv6Multicast AndAlso Not a.IsIPv6SiteLocal) _
    .First() _
    .ToString()

Это может взорваться, поэтому не рассматривайте его как производственный код.

1 голос
/ 28 апреля 2011

Вот мое решение для получения маршрутизируемого IPv4 IP без использования внешней службы:

  Function GetLocalIP() As String
    Dim IPList As System.Net.IPHostEntry = System.Net.Dns.GetHostEntry(System.Net.Dns.GetHostName)

    For Each IPaddress In IPList.AddressList
      'Only return IPv4 routable IPs
      If (IPaddress.AddressFamily = Sockets.AddressFamily.InterNetwork) AndAlso (Not IsPrivateIP(IPaddress.ToString)) Then
        Return IPaddress.ToString
      End If
    Next
    Return ""
  End Function

  Function IsPrivateIP(ByVal CheckIP As String) As Boolean
    Dim Quad1, Quad2 As Integer

    Quad1 = CInt(CheckIP.Substring(0, CheckIP.IndexOf(".")))
    Quad2 = CInt(CheckIP.Substring(CheckIP.IndexOf(".") + 1).Substring(0, CheckIP.IndexOf(".")))
    Select Case Quad1
      Case 10
        Return True
      Case 172
        If Quad2 >= 16 And Quad2 <= 31 Then Return True
      Case 192
        If Quad2 = 168 Then Return True
    End Select
    Return False
  End Function

Обратите внимание, что мой код также проверяет возможность маршрутизации диапазона (IsPrivateIP). Вы можете удалить или изменить эту часть, если вы ищете что-то еще.

0 голосов
/ 01 сентября 2016
 Dim localIp As IPHostEntry = Dns.GetHostEntry(Dns.GetHostName())
 txtLocal.Text = localIp.AddressList(1).ToString

Обратите внимание, что я изменил индекс (0) на (1).

0 голосов
/ 16 июля 2014

Сначала необходимо импортировать системное пространство имен в приложение, а затем создать экземпляр System.Net.NetworkInformation.IPAddressInformation и использовать его как таковой

Пример

  Imports system.data.sqlclient
    imports system

Public class Form1
   Dim IPAdd As System.Net.NetworkInformation.IPAddressInformation

Private Sub Button1_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button1.Click

 MsgBox("My IP Address is " & IPAdd.Address.ToString)
    End Sub
End Class
0 голосов
/ 18 июня 2014

Я сам искал ответ на этот вопрос и не мог найти подходящего для своих нужд. Мне удалось поэкспериментировать с различными ответами в сети, пока я не придумал это (прекрасно работает!). Просто думал, что поделюсь, так как этот пост является лучшим результатом через Google.

    ''''Routine to fetch IPv4 Network addresses for all local network interfaces.
    Dim adapters As NetworkInterface() = NetworkInterface.GetAllNetworkInterfaces()
    Dim adapter As NetworkInterface
        For Each adapter In adapters
            Dim properties As IPInterfaceProperties = adapter.GetIPProperties()
            If properties.UnicastAddresses.Count > 0 Then
                For Each unicastadress As UnicastIPAddressInformation In properties.UnicastAddresses
                    Dim ip As IPAddress = unicastadress.Address
                    If ip.AddressFamily = AddressFamily.InterNetwork Then
                        ComboBox1.Items.Add(ip.ToString)
                    End If
                Next unicastadress
            End If
        Next adapter
0 голосов
/ 23 мая 2014

Что-то, возможно, забавно, эта маленькая функция, которая покажет все IP-адреса на вашем компьютере:

Public Function getOwnIp() As String
        Dim hostIP As IPHostEntry = Dns.GetHostEntry(Dns.GetHostName())
        Dim position As Integer = 0
        Dim ip As String = Nothing
        While ipList < hostIP.AddressList.Length
            ip += hostIP.AddressList(position).ToString & vbCrLf
            position += 1
        End While`enter code here`
        Return ip
    End Function
0 голосов
/ 31 мая 2012

Я думаю, вы должны использовать это:

 Dim tmpHostName As String = System.Net.Dns.GetHostName()
 myIPaddress = System.Net.Dns.GetHostByName(tmpHostName).AddressList(0).ToString()

GetHostByName устарел, но это способ получить IPv4. Зачем? Поскольку функция getbyhostname создается до IPv6, функция получает только соединение IPv4, а не fe80::9c09:e2e:4736:4c62%11.

.
...