3v4l.org

run code in 150+ php & hhvm versions
Bugs & Features
<?php $pattern = <<<REGEXP ! ^ (?P<scheme> [a-z][a-z0-9+.\-]* ) [:] # scheme is mandatory, and followed by a : (?: [/][/] # // indicates that this component is the authority (?: (?P<user> [^:@/]+ ) (?: [:] (?P<pass> [^:@/]+ ) )? [@] )? # auth details are optional (?P<host> [^:/]* ) # host is mandatory. Technically it should be at least 1 char, but PHP has # internal schemes that violate this rule and as much as I dislike it, I # feel that we should pass this (?: [:] (?P<port> [0-9]+ ) )? # port is simply a sequence of decimal digits (?= [/?#]|$ ) # path must be missing or begin with / if authority is present )? (?P<path> [^?#]+ )? # path is everything up to the query/fragment (?: [?] (?P<query> [^#]+ ) )? # query is optional (?: [#] (?P<fragment> .+ ) )? # fragment is optional $ !xi REGEXP; $url = 'http://foo.com/test?thing=stuff#fragment'; preg_match($pattern, $url, $matches); print_r($matches);
Output for 4.3.3 - 5.6.28, hhvm-3.10.0 - 3.12.0, 7.0.0 - 7.1.0
Array ( [0] => http://foo.com/test?thing=stuff#fragment [scheme] => http [1] => http [user] => [2] => [pass] => [3] => [host] => foo.com [4] => foo.com [port] => [5] => [path] => /test [6] => /test [query] => thing=stuff [7] => thing=stuff [fragment] => fragment [8] => fragment )
Output for 4.3.0 - 4.3.2
Array ( [0] => http://foo.com/test?thing=stuff#fragment [1] => http [2] => [3] => [4] => foo.com [5] => [6] => /test [7] => thing=stuff [8] => fragment )