Preserve the host name of address when parsing /etc/hosts file

Motivation:

When an InetNameResolver resolves a name, it is expected to reserve the
requested host name in the resolved InetAddress.

DefaultHostsFileEntriesResolver does not preserve the host name. For
example, resolving 'localhost' will return an InetAddress whose address
is '127.0.0.1', but its getHostString() will not return 'localhost' but
just '127.0.0.1'.

Modifications:

Fix the construction of parsed InetAddresses in HostsFileParser

Result:

Host name is preserved in the resolved InetAddress
This commit is contained in:
Trustin Lee 2016-02-04 20:23:48 +09:00 committed by Norman Maurer
parent 075a54af3e
commit ef0e053202

View File

@ -31,6 +31,7 @@ import java.util.Collections;
import java.util.List; import java.util.List;
import java.util.HashMap; import java.util.HashMap;
import java.util.Map; import java.util.Map;
import java.util.regex.Pattern;
import static io.netty.util.internal.ObjectUtil.*; import static io.netty.util.internal.ObjectUtil.*;
@ -43,6 +44,8 @@ public final class HostsFileParser {
private static final String WINDOWS_HOSTS_FILE_RELATIVE_PATH = "\\system32\\drivers\\etc\\hosts"; private static final String WINDOWS_HOSTS_FILE_RELATIVE_PATH = "\\system32\\drivers\\etc\\hosts";
private static final String X_PLATFORMS_HOSTS_FILE_PATH = "/etc/hosts"; private static final String X_PLATFORMS_HOSTS_FILE_PATH = "/etc/hosts";
private static final Pattern WHITESPACES = Pattern.compile("[ \t]+");
private static final InternalLogger logger = InternalLoggerFactory.getInstance(HostsFileParser.class); private static final InternalLogger logger = InternalLoggerFactory.getInstance(HostsFileParser.class);
private static File locateHostsFile() { private static File locateHostsFile() {
@ -126,7 +129,7 @@ public final class HostsFileParser {
// split // split
List<String> lineParts = new ArrayList<String>(); List<String> lineParts = new ArrayList<String>();
for (String s: line.split("[ \t]+")) { for (String s: WHITESPACES.split(line)) {
if (!s.isEmpty()) { if (!s.isEmpty()) {
lineParts.add(s); lineParts.add(s);
} }
@ -145,21 +148,23 @@ public final class HostsFileParser {
continue; continue;
} }
InetAddress inetAddress = InetAddress.getByAddress(ipBytes);
// loop over hostname and aliases // loop over hostname and aliases
for (int i = 1; i < lineParts.size(); i ++) { for (int i = 1; i < lineParts.size(); i ++) {
String hostname = lineParts.get(i); String hostname = lineParts.get(i);
if (!entries.containsKey(hostname)) { if (!entries.containsKey(hostname)) {
// trying to map a host to multiple IPs is wrong // trying to map a host to multiple IPs is wrong
// only the first entry is honored // only the first entry is honored
entries.put(hostname, inetAddress); entries.put(hostname, InetAddress.getByAddress(hostname, ipBytes));
} }
} }
} }
return entries; return entries;
} finally { } finally {
buff.close(); try {
buff.close();
} catch (IOException e) {
logger.warn("Failed to close a reader", e);
}
} }
} }