Modern applications often need the ability to learn information about hosts out on the network. One key class in this process for Java developers is the java.net.InetAddress
. This class allows you to figure out various information about hosts, as well as discovering host information by different means.
InetAddress is a deceptively simple class to use, in that it provides a simple API for working with some very complex concepts. For instance, it provides a standard interface for discovering IPv4 IP addresses as well as IPv6 IP addresses. In addition, it distinguishes between multicast and unicast address types transparently. Finally, there are facilities built-in for determining if a host is reachable.
Here are some useful tidbits to understand:
- If the internet address is IPv6, the returned object from the static methods of
InetAddress
will be anInet6Address
object. Likewise, if the address is IPv4, the returned object from the static methods will be anInet4Address
object. - The IP Address lookup can be by
byte[]
, in which case highest-order byte format is used - so for the ip address127.0.0.1
, you would have thebyte[]
{127,0,0,1}
. - Host name resolution is goverened by caching that can be controlled by some Java system properties - from the Javadoc:
networkaddress.cache.ttl (default: -1)
Indicates the caching policy for successful name lookups from the name service. The value is specified as as integer to indicate the number of seconds to cache the successful lookup. A value of -1 indicates "cache forever".networkaddress.cache.negative.ttl (default: 10)
Indicates the caching policy for un-successful name lookups from the name service. The value is specified as as integer to indicate the number of seconds to cache the failure for un-successful lookups. A value of 0 indicates "never cache". A value of -1 indicates "cache forever".
Here is a little example class that shows some of the common techniques for using InetAddress to discover various information:
package org.javalobby.tnt.net; import java.net.InetAddress; public class InetAddressTest { public static void main(String[] args) throws Exception { // Get by host name InetAddress javalobby = InetAddress.getByName("javalobby.org"); // Get by IP as host name InetAddress byIpAsName = InetAddress.getByName("64.69.35.190"); // Get by IP as highest-order byte array InetAddress byIp = InetAddress.getByAddress(new byte[] { 64, 69, 35, (byte)190}); // Get Local address InetAddress local = InetAddress.getLocalHost(); // Get Local Address by Loopback IP InetAddress localByIp = InetAddress.getByName("127.0.0.1"); printAddressInfo("By-Name (Javalobby.org)", javalobby); printAddressInfo("By-Name (Using IP as Host)", byIpAsName); printAddressInfo("By-IP: (64.69.35.190)", byIp); printAddressInfo("Special Local Host", local); printAddressInfo("Local Host By IP", localByIp); } private static void printAddressInfo(String name, InetAddress... hosts) throws Exception { System.out.println("===== Printing Info for: '" + name + "' ====="); for(InetAddress host : hosts) { System.out.println("Host Name: " + host.getHostName()); System.out.println("Canonical Host Name: " + host.getCanonicalHostName()); System.out.println("Host Address: " + host.getHostAddress()); System.out.println("Calculated Host Address: " + getIpAsString(host)); System.out.print("Is Any Local: " + host.isAnyLocalAddress()); System.out.print(" - Is Link Local: " + host.isLinkLocalAddress()); System.out.print(" - Is Loopback: " + host.isLoopbackAddress()); System.out.print(" - Is Multicast: " + host.isMulticastAddress()); System.out.println(" - Is Site Local: " + host.isSiteLocalAddress()); System.out.println("Is Reachable in 2 seconds: " + host.isReachable(2000)); } } private static String getIpAsString(InetAddress address) { byte[] ipAddress = address.getAddress(); StringBuffer str = new StringBuffer(); for(int i=0; i0) str.append('.'); str.append(ipAddress[i] & 0xFF); } return str.toString(); }}
Here is an example output:
===== Printing Info for: 'By-Name (Javalobby.org)' =====Host Name: javalobby.orgCanonical Host Name: www.javalobby.orgHost Address: 64.69.35.190Calculated Host Address: 64.69.35.190Is Any Local: false - Is Link Local: false - Is Loopback: false - Is Multicast: false - Is Site Local: falseIs Reachable in 2 seconds: true===== Printing Info for: 'By-Name (Using IP as Host)' =====Host Name: www.javalobby.orgCanonical Host Name: www.javalobby.orgHost Address: 64.69.35.190Calculated Host Address: 64.69.35.190Is Any Local: false - Is Link Local: false - Is Loopback: false - Is Multicast: false - Is Site Local: falseIs Reachable in 2 seconds: true===== Printing Info for: 'By-IP: (64.69.35.190)' =====Host Name: www.javalobby.orgCanonical Host Name: www.javalobby.orgHost Address: 64.69.35.190Calculated Host Address: 64.69.35.190Is Any Local: false - Is Link Local: false - Is Loopback: false - Is Multicast: false - Is Site Local: falseIs Reachable in 2 seconds: true===== Printing Info for: 'Special Local Host' =====Host Name: COFFEE-BYTES-2Canonical Host Name: 192.168.1.101Host Address: 192.168.1.101Calculated Host Address: 192.168.1.101Is Any Local: false - Is Link Local: false - Is Loopback: false - Is Multicast: false - Is Site Local: trueIs Reachable in 2 seconds: true===== Printing Info for: 'Local Host By IP' =====Host Name: localhostCanonical Host Name: localhostHost Address: 127.0.0.1Calculated Host Address: 127.0.0.1Is Any Local: false - Is Link Local: false - Is Loopback: true - Is Multicast: false - Is Site Local: falseIs Reachable in 2 seconds: trueUntil next time,R.J. Lorimer Contributing Editor - rj -at- javalobby.org Author - http://www.coffee-bytes.com Software Consultant - http://www.crosslogic.com