IPAddress.IsLoopback(IPAddress) Método
Definição
Importante
Algumas informações se referem a produtos de pré-lançamento que podem ser substancialmente modificados antes do lançamento. A Microsoft não oferece garantias, expressas ou implícitas, das informações aqui fornecidas.
Indica se o endereço IP especificado é o endereço de loopback.
public:
static bool IsLoopback(System::Net::IPAddress ^ address);
public static bool IsLoopback (System.Net.IPAddress address);
static member IsLoopback : System.Net.IPAddress -> bool
Public Shared Function IsLoopback (address As IPAddress) As Boolean
Parâmetros
- address
- IPAddress
Um endereço IP.
Retornos
true
se address
é o endereço de loopback, caso contrário, false
.
Exemplos
O exemplo de código a seguir usa o IsLoopback método para determinar se o endereço especificado é um endereço de loopback.
#using <System.dll>
using namespace System;
using namespace System::Net;
using namespace System::Net::Sockets;
// This method calls the IPAddress::Parse method to check if the
// passed ipAddress parameter is in the correct format.
// Then it checks whether it represents a loopback address.
// Finally, it displays the results.
void parse( String^ ipAddress )
{
String^ loopBack = " is not a loopback address.";
try
{
// Perform syntax check by parsing the address string entered by the user.
IPAddress^ address = IPAddress::Parse( ipAddress );
// Perform semantic check by verifying that the address is a valid IPv4
// or IPv6 loopback address.
if ( IPAddress::IsLoopback( address ) && address->AddressFamily == AddressFamily::InterNetworkV6 )
loopBack = String::Concat( " is an IPv6 loopback address whose internal format is: ", address, "." );
else
if ( IPAddress::IsLoopback( address ) && address->AddressFamily == AddressFamily::InterNetwork )
loopBack = String::Concat( " is an IPv4 loopback address whose internal format is: ", address, "." );
// Display the results.
Console::WriteLine( "Your input address: \" {0} \" {1}", ipAddress, loopBack );
}
catch ( FormatException^ e )
{
Console::WriteLine( "FormatException caught!!!" );
Console::WriteLine( "Source : {0}", e->Source );
Console::WriteLine( "Message : {0}", e->Message );
}
catch ( Exception^ e )
{
Console::WriteLine( "Exception caught!!!" );
Console::WriteLine( "Source : {0}", e->Source );
Console::WriteLine( "Message : {0}", e->Message );
}
}
int main()
{
array<String^>^args = Environment::GetCommandLineArgs();
if ( args->Length == 1 )
{
// No parameters entered. Display program usage.
Console::WriteLine( "Please enter an IP address." );
Console::WriteLine( "Usage: >ipaddress_isloopback any IPv4 or IPv6 address." );
Console::WriteLine( "Example: >ipaddress_isloopback 127.0.0.1" );
Console::WriteLine( "Example: >ipaddress_isloopback 0:0:0:0:0:0:0:1" );
}
else
parse( args[ 1 ] );
// Parse the address string entered by the user.
}
using System;
using System.Net;
using System.Net.Sockets;
class IsLoopbackTest
{
private static void Main(string[] args)
{
if (args.Length == 0)
{
// No parameters entered. Display program usage.
Console.WriteLine("Please enter an IP address.");
Console.WriteLine("Usage: >ipaddress_isloopback any IPv4 or IPv6 address.");
Console.WriteLine("Example: >ipaddress_isloopback 127.0.0.1");
Console.WriteLine("Example: >ipaddress_isloopback 0:0:0:0:0:0:0:1");
return;
}
else
{
// Parse the address string entered by the user.
parse(args[0]);
}
}
// This method calls the IPAddress.Parse method to check if the
// passed ipAddress parameter is in the correct format.
// Then it checks whether it represents a loopback address.
// Finally, it displays the results.
private static void parse(string ipAddress)
{
string loopBack=" is not a loopback address.";
try
{
// Perform syntax check by parsing the address string entered by the user.
IPAddress address = IPAddress.Parse(ipAddress);
// Perform semantic check by verifying that the address is a valid IPv4
// or IPv6 loopback address.
if(IPAddress.IsLoopback(address)&& address.AddressFamily == AddressFamily.InterNetworkV6)
loopBack = " is an IPv6 loopback address " +
"whose internal format is: " + address.ToString() + ".";
else
if(IPAddress.IsLoopback(address) && address.AddressFamily == AddressFamily.InterNetwork)
loopBack = " is an IPv4 loopback address " +
"whose internal format is: " + address.ToString() + ".";
// Display the results.
Console.WriteLine("Your input address: " + "\"" + ipAddress + "\"" + loopBack);
}
catch(FormatException e)
{
Console.WriteLine("FormatException caught!!!");
Console.WriteLine("Source : " + e.Source);
Console.WriteLine("Message : " + e.Message);
}
catch(Exception e)
{
Console.WriteLine("Exception caught!!!");
Console.WriteLine("Source : " + e.Source);
Console.WriteLine("Message : " + e.Message);
}
}
}
Imports System.Net
Imports System.Net.Sockets
_
Class IsLoopbackTest
'Entry point which delegates to C-style main Private Function
Public Overloads Shared Sub Main()
Main(System.Environment.GetCommandLineArgs())
End Sub
Overloads Private Shared Sub Main(args() As String)
If args.Length = 1 Then
' No parameters entered. Display program usage.
Console.WriteLine("Please enter an IP address.")
Console.WriteLine("Usage: >ipaddress_isloopback any IPv4 or IPv6 address.")
Console.WriteLine("Example: >ipaddress_isloopback 127.0.0.1")
Console.WriteLine("Example: >ipaddress_isloopback 0:0:0:0:0:0:0:1")
Return
' Parse the address string entered by the user.
Else
parse(args(1))
End If
End Sub
' This method calls the IPAddress.Parse method to check whether the
' passed ipAddress parameter is in the correct format.
' Then it checks whether it represents a loopback address.
' Finally, it displays the results.
Private Shared Sub parse(ipAdd As String)
Dim loopBack As String = " is not a loopback address."
Try
' Perform syntax check by parsing the address string entered by the user.
Dim address As IPAddress = IPAddress.Parse(ipAdd)
' Perform semantic check by verifying that the address is a valid IPv4
' or IPv6 loopback address.
If IPAddress.IsLoopback(address) And address.AddressFamily = AddressFamily.InterNetworkV6 Then
loopBack = " is an IPv6 loopback address " + "whose internal format is: " + address.ToString() + "."
Else
If IPAddress.IsLoopback(address) And address.AddressFamily = AddressFamily.InterNetwork Then
loopBack = " is an IPv4 loopback address " + "whose internal format is: " + address.ToString() + "."
End If
End If
' Display the results.
Console.WriteLine(("Your input address: " + """" + ipAdd + """" + loopBack))
Catch e As FormatException
Console.WriteLine("FormatException caught!!!")
Console.WriteLine(("Source : " + e.Source))
Console.WriteLine(("Message : " + e.Message))
Catch e As Exception
Console.WriteLine("Exception caught!!!")
Console.WriteLine(("Source : " + e.Source))
Console.WriteLine(("Message : " + e.Message))
End Try
End Sub
End Class
Comentários
O IsLoopback método se compara address
a Loopback e retorna true
se os dois endereços IP são os mesmos.
No caso de IPv4, que o IsLoopback método retorna true
para qualquer endereço IP do formulário 127.X.Y.Z (em que X, Y e Z estão no intervalo 0-255), não apenas Loopback (127.0.0.1).