Revert "HttpURI cleanup"

This reverts commit 0913e7d7da.
This commit is contained in:
Greg Wilkins 2016-07-27 20:45:34 +10:00
parent 7669ea0365
commit 162d6fc722
3 changed files with 95 additions and 74 deletions

View File

@ -33,15 +33,13 @@ import org.eclipse.jetty.util.UrlEncoded;
/* ------------------------------------------------------------ */ /* ------------------------------------------------------------ */
/** Http URI. /** Http URI.
* Parse a HTTP URI from a string or byte array. Given a URI * Parse a HTTP URI from a string or byte array. Given a URI
* <code>http://user:password@host:port/path;ignored/%69nfo;param?query#fragment</code> * <code>http://user@host:port/path/info;param?query#fragment</code>
* this class will split it into the following undecoded optional elements:<ul> * this class will split it into the following undecoded optional elements:<ul>
* <li>{@link #getScheme()} - http:</li> * <li>{@link #getScheme()} - http:</li>
* <li>{@link #getUser()} - user:password</li> * <li>{@link #getAuthority()} - //name@host:port</li>
* <li>{@link #getAuthority()} - host:port</li>
* <li>{@link #getHost()} - host</li> * <li>{@link #getHost()} - host</li>
* <li>{@link #getPort()} - port</li> * <li>{@link #getPort()} - port</li>
* <li>{@link #getPath()} - /path;ignored/%69nfo;param</li> * <li>{@link #getPath()} - /path/info</li>
* <li>{@link #getDecodedPath()} - /path/info</li>
* <li>{@link #getParam()} - param</li> * <li>{@link #getParam()} - param</li>
* <li>{@link #getQuery()} - query</li> * <li>{@link #getQuery()} - query</li>
* <li>{@link #getFragment()} - fragment</li> * <li>{@link #getFragment()} - fragment</li>
@ -78,6 +76,28 @@ public class HttpURI
String _uri; String _uri;
String _decodedPath; String _decodedPath;
/* ------------------------------------------------------------ */
/**
* Construct a normalized URI.
* Port is not set if it is the default port.
* @param scheme the URI scheme
* @param host the URI hose
* @param port the URI port
* @param path the URI path
* @param param the URI param
* @param query the URI query
* @param fragment the URI fragment
* @return the normalized URI
*/
public static HttpURI createHttpURI(String scheme, String host, int port, String path, String param, String query, String fragment)
{
if (port==80 && HttpScheme.HTTP.is(scheme))
port=0;
if (port==443 && HttpScheme.HTTPS.is(scheme))
port=0;
return new HttpURI(scheme,host,port,path,param,query,fragment);
}
/* ------------------------------------------------------------ */ /* ------------------------------------------------------------ */
public HttpURI() public HttpURI()
{ {
@ -88,7 +108,7 @@ public class HttpURI
{ {
_scheme = scheme; _scheme = scheme;
_host = host; _host = host;
_port = (port<0 && (HttpScheme.HTTP.is(_scheme)||HttpScheme.HTTPS.is(_scheme)))?0:port; _port = port;
_path = path; _path = path;
_param = param; _param = param;
_query = query; _query = query;
@ -99,7 +119,6 @@ public class HttpURI
public HttpURI(HttpURI uri) public HttpURI(HttpURI uri)
{ {
this(uri._scheme,uri._host,uri._port,uri._path,uri._param,uri._query,uri._fragment); this(uri._scheme,uri._host,uri._port,uri._path,uri._param,uri._query,uri._fragment);
_user=uri._user;
_uri=uri._uri; _uri=uri._uri;
} }
@ -107,7 +126,7 @@ public class HttpURI
public HttpURI(String uri) public HttpURI(String uri)
{ {
_port=-1; _port=-1;
parse(State.START,uri); parse(State.START,uri,0,uri.length());
} }
/* ------------------------------------------------------------ */ /* ------------------------------------------------------------ */
@ -139,11 +158,22 @@ public class HttpURI
/* ------------------------------------------------------------ */ /* ------------------------------------------------------------ */
public HttpURI(String scheme, String host, int port, String pathQuery) public HttpURI(String scheme, String host, int port, String pathQuery)
{ {
_uri=null;
_scheme=scheme; _scheme=scheme;
_host=host; _host=host;
_port = (port<0 && (HttpScheme.HTTP.is(_scheme)||HttpScheme.HTTPS.is(_scheme)))?0:port; _port=port;
parse(State.PATH,pathQuery);
_uri=null; parse(State.PATH,pathQuery,0,pathQuery.length());
}
/* ------------------------------------------------------------ */
public void parse(String uri)
{
clear();
_uri=uri;
parse(State.START,uri,0,uri.length());
} }
/* ------------------------------------------------------------ */ /* ------------------------------------------------------------ */
@ -160,18 +190,35 @@ public class HttpURI
if (HttpMethod.CONNECT.is(method)) if (HttpMethod.CONNECT.is(method))
_path=uri; _path=uri;
else else
parse(uri.startsWith("/")?State.PATH:State.START,uri); parse(uri.startsWith("/")?State.PATH:State.START,uri,0,uri.length());
} }
/* ------------------------------------------------------------ */ /* ------------------------------------------------------------ */
private void parse(State state, final String uri) @Deprecated
public void parseConnect(String uri)
{
clear();
_uri=uri;
_path=uri;
}
/* ------------------------------------------------------------ */
public void parse(String uri, int offset, int length)
{
clear();
int end=offset+length;
_uri=uri.substring(offset,end);
parse(State.START,uri,offset,end);
}
/* ------------------------------------------------------------ */
private void parse(State state, final String uri, final int offset, final int end)
{ {
boolean encoded=false; boolean encoded=false;
int mark=0; int mark=offset;
int end=uri.length();
int path_mark=0; int path_mark=0;
for (int i=0; i<end; i++) for (int i=offset; i<end; i++)
{ {
char c=uri.charAt(i); char c=uri.charAt(i);
@ -295,13 +342,12 @@ public class HttpURI
{ {
case '/': case '/':
_host = uri.substring(mark,i); _host = uri.substring(mark,i);
_port = 0;
path_mark=mark=i; path_mark=mark=i;
state=State.PATH; state=State.PATH;
break; break;
case ':': case ':':
_host=(i > mark)?uri.substring(mark,i):""; if (i > mark)
_port = 0; _host=uri.substring(mark,i);
mark=i+1; mark=i+1;
state=State.PORT; state=State.PORT;
break; break;
@ -515,13 +561,6 @@ public class HttpURI
/* ------------------------------------------------------------ */ /* ------------------------------------------------------------ */
public int getPort() public int getPort()
{ {
if (_port==0)
{
if (HttpScheme.HTTP.is(_scheme))
return 80;
if (HttpScheme.HTTPS.is(_scheme))
return 443;
}
return _port; return _port;
} }
@ -635,7 +674,7 @@ public class HttpURI
out.append(_host); out.append(_host);
} }
if (_port>0 && !(_port==80&&HttpScheme.HTTP.is(_scheme)) && !(_port==443&&HttpScheme.HTTPS.is(_scheme))) if (_port>0)
out.append(':').append(_port); out.append(':').append(_port);
if (_path!=null) if (_path!=null)
@ -704,7 +743,7 @@ public class HttpURI
_param=null; _param=null;
_fragment=null; _fragment=null;
if (path!=null) if (path!=null)
parse(State.PATH,path); parse(State.PATH,path,0,path.length());
} }
/* ------------------------------------------------------------ */ /* ------------------------------------------------------------ */
@ -741,4 +780,6 @@ public class HttpURI
{ {
return _user; return _user;
} }
} }

View File

@ -45,9 +45,10 @@ public class HttpURITest
private void assertInvalidURI(String invalidURI, String message) private void assertInvalidURI(String invalidURI, String message)
{ {
HttpURI uri = new HttpURI();
try try
{ {
new HttpURI(invalidURI); uri.parse(invalidURI);
fail(message); fail(message);
} }
catch (IllegalArgumentException e) catch (IllegalArgumentException e)
@ -56,6 +57,28 @@ public class HttpURITest
} }
} }
@Test
public void testParse()
{
HttpURI uri = new HttpURI();
uri.parse("*");
assertThat(uri.getHost(),nullValue());
assertThat(uri.getPath(),is("*"));
uri.parse("/foo/bar");
assertThat(uri.getHost(),nullValue());
assertThat(uri.getPath(),is("/foo/bar"));
uri.parse("//foo/bar");
assertThat(uri.getHost(),is("foo"));
assertThat(uri.getPath(),is("/bar"));
uri.parse("http://foo/bar");
assertThat(uri.getHost(),is("foo"));
assertThat(uri.getPath(),is("/bar"));
}
@Test @Test
public void testParseRequestTarget() public void testParseRequestTarget()
{ {
@ -227,47 +250,4 @@ public class HttpURITest
assertEquals(uri.getAuthority(), "example.com:8888"); assertEquals(uri.getAuthority(), "example.com:8888");
assertEquals(uri.getUser(), "user:password"); assertEquals(uri.getUser(), "user:password");
} }
@Test
public void testComplete() throws Exception
{
HttpURI uri = new HttpURI("scheme://user:password@host:99/path;ignored/%69nfo;param?query+string#fragment");
assertEquals("scheme",uri.getScheme());
assertEquals("user:password",uri.getUser());
assertEquals("host",uri.getHost());
assertEquals(99,uri.getPort());
assertEquals("host:99",uri.getAuthority());
assertEquals("/path;ignored/%69nfo;param",uri.getPath());
assertEquals("/path/info",uri.getDecodedPath());
assertEquals("param",uri.getParam());
assertEquals("query+string",uri.getQuery());
assertEquals("fragment",uri.getFragment());
}
@Test
public void testDefaultPorts() throws Exception
{
HttpURI uri = new HttpURI("/path/info");
assertEquals(-1,uri.getPort());
uri = new HttpURI("http:/path/info");
assertEquals(-1,uri.getPort());
uri = new HttpURI("http://host/path/info");
assertEquals(80,uri.getPort());
uri = new HttpURI("https://host/path/info");
assertEquals(443,uri.getPort());
uri = new HttpURI("http://host:8080/path/info");
assertEquals(8080,uri.getPort());
uri = new HttpURI("http","host",-1,"/path?query");
assertEquals(80,uri.getPort());
}
} }

View File

@ -248,7 +248,7 @@ public class PushBuilderImpl implements PushBuilder
_fields.add(HttpHeader.IF_MODIFIED_SINCE,_lastModified); _fields.add(HttpHeader.IF_MODIFIED_SINCE,_lastModified);
} }
HttpURI uri = new HttpURI(_request.getScheme(),_request.getServerName(),_request.getServerPort(),path,param,query,null); HttpURI uri = HttpURI.createHttpURI(_request.getScheme(),_request.getServerName(),_request.getServerPort(),path,param,query,null);
MetaData.Request push = new MetaData.Request(_method,uri,_request.getHttpVersion(),_fields); MetaData.Request push = new MetaData.Request(_method,uri,_request.getHttpVersion(),_fields);
if (LOG.isDebugEnabled()) if (LOG.isDebugEnabled())