RFC 3986 conformance: revised and optimized `URIUtils#extractHost`
This commit is contained in:
parent
0524eed4b9
commit
6395fa7c79
|
@ -250,56 +250,17 @@ public class URIUtils {
|
||||||
if (uri == null) {
|
if (uri == null) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
HttpHost target = null;
|
final URIBuilder uriBuilder = new URIBuilder(uri);
|
||||||
if (uri.isAbsolute()) {
|
final String scheme = uriBuilder.getScheme();
|
||||||
int port = uri.getPort(); // may be overridden later
|
final String host = uriBuilder.getHost();
|
||||||
String host = uri.getHost();
|
final int port = uriBuilder.getPort();
|
||||||
if (host == null) { // normal parse failed; let's do it ourselves
|
|
||||||
// authority does not seem to care about the valid character-set for host names
|
|
||||||
host = uri.getAuthority();
|
|
||||||
if (host != null) {
|
|
||||||
// Strip off any leading user credentials
|
|
||||||
final int at = host.indexOf('@');
|
|
||||||
if (at >= 0) {
|
|
||||||
if (host.length() > at+1 ) {
|
|
||||||
host = host.substring(at+1);
|
|
||||||
} else {
|
|
||||||
host = null; // @ on its own
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// Extract the port suffix, if present
|
|
||||||
if (host != null) {
|
|
||||||
final int colon = host.indexOf(':');
|
|
||||||
if (colon >= 0) {
|
|
||||||
final int pos = colon + 1;
|
|
||||||
int len = 0;
|
|
||||||
for (int i = pos; i < host.length(); i++) {
|
|
||||||
if (Character.isDigit(host.charAt(i))) {
|
|
||||||
len++;
|
|
||||||
} else {
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (len > 0) {
|
|
||||||
try {
|
|
||||||
port = Integer.parseInt(host.substring(pos, pos + len));
|
|
||||||
} catch (final NumberFormatException ex) {
|
|
||||||
}
|
|
||||||
}
|
|
||||||
host = host.substring(0, colon);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
final String scheme = uri.getScheme();
|
|
||||||
if (!TextUtils.isBlank(host)) {
|
if (!TextUtils.isBlank(host)) {
|
||||||
try {
|
try {
|
||||||
target = new HttpHost(scheme, host, port);
|
return new HttpHost(scheme, host, port);
|
||||||
} catch (final IllegalArgumentException ignore) {
|
} catch (final IllegalArgumentException ignore) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
return null;
|
||||||
return target;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -230,9 +230,9 @@ public class TestURIUtils {
|
||||||
|
|
||||||
Assert.assertEquals(new HttpHost("localhost",8080),
|
Assert.assertEquals(new HttpHost("localhost",8080),
|
||||||
URIUtils.extractHost(new URI("http://localhost:8080/;sessionid=stuff/abcd")));
|
URIUtils.extractHost(new URI("http://localhost:8080/;sessionid=stuff/abcd")));
|
||||||
Assert.assertEquals(new HttpHost("localhost",8080),
|
Assert.assertEquals(null,
|
||||||
URIUtils.extractHost(new URI("http://localhost:8080;sessionid=stuff/abcd")));
|
URIUtils.extractHost(new URI("http://localhost:8080;sessionid=stuff/abcd")));
|
||||||
Assert.assertEquals(new HttpHost("localhost",-1),
|
Assert.assertEquals(null,
|
||||||
URIUtils.extractHost(new URI("http://localhost:;sessionid=stuff/abcd")));
|
URIUtils.extractHost(new URI("http://localhost:;sessionid=stuff/abcd")));
|
||||||
Assert.assertEquals(null,
|
Assert.assertEquals(null,
|
||||||
URIUtils.extractHost(new URI("http://:80/robots.txt")));
|
URIUtils.extractHost(new URI("http://:80/robots.txt")));
|
||||||
|
|
Loading…
Reference in New Issue