summaryrefslogtreecommitdiff
path: root/ext
diff options
context:
space:
mode:
authorjhdxr <jhdxr@php.net>2017-06-21 02:03:13 +0800
committerJoe Watkins <krakjoe@php.net>2017-06-22 11:52:06 +0100
commitdb287b23030a2ac16bd9e2524d7e8bbe1b4a4d9a (patch)
treef190bbf966e66dc753974526f095de535fa35c6f /ext
parentb3bd379198e3b47a54b0f9aa569ac31d7c2c9e87 (diff)
downloadphp-git-db287b23030a2ac16bd9e2524d7e8bbe1b4a4d9a.tar.gz
fix bug #74780 parse_url() borken when query string contains colon
Diffstat (limited to 'ext')
-rw-r--r--ext/standard/tests/url/bug74780.phpt38
-rw-r--r--ext/standard/url.c5
2 files changed, 43 insertions, 0 deletions
diff --git a/ext/standard/tests/url/bug74780.phpt b/ext/standard/tests/url/bug74780.phpt
new file mode 100644
index 0000000000..ae464d971b
--- /dev/null
+++ b/ext/standard/tests/url/bug74780.phpt
@@ -0,0 +1,38 @@
+--TEST--
+Bug #74780 parse_url() borks when query string contains colon
+--FILE--
+<?php
+var_dump(
+ parse_url('//php.net/path?query=1:2'),
+ parse_url('//php.net/path.php?query=a:b'),
+ parse_url('//username@php.net/path?query=1:2')
+);
+
+?>
+--EXPECT--
+array(3) {
+ ["host"]=>
+ string(7) "php.net"
+ ["path"]=>
+ string(5) "/path"
+ ["query"]=>
+ string(9) "query=1:2"
+}
+array(3) {
+ ["host"]=>
+ string(7) "php.net"
+ ["path"]=>
+ string(9) "/path.php"
+ ["query"]=>
+ string(9) "query=a:b"
+}
+array(4) {
+ ["host"]=>
+ string(7) "php.net"
+ ["user"]=>
+ string(8) "username"
+ ["path"]=>
+ string(5) "/path"
+ ["query"]=>
+ string(9) "query=1:2"
+} \ No newline at end of file
diff --git a/ext/standard/url.c b/ext/standard/url.c
index 86f8c45563..9c42afbdea 100644
--- a/ext/standard/url.c
+++ b/ext/standard/url.c
@@ -112,6 +112,10 @@ PHPAPI php_url *php_url_parse_ex(char const *str, size_t length)
if (!isalpha(*p) && !isdigit(*p) && *p != '+' && *p != '.' && *p != '-') {
if (e + 1 < ue && e < s + strcspn(s, "?#")) {
goto parse_port;
+ } else if (s + 1 < ue && *s == '/' && *(s + 1) == '/') { /* relative-scheme URL */
+ s += 2;
+ e = 0;
+ goto parse_host;
} else {
goto just_path;
}
@@ -208,6 +212,7 @@ PHPAPI php_url *php_url_parse_ex(char const *str, size_t length)
goto just_path;
}
+ parse_host:
/* Binary-safe strcspn(s, "/?#") */
e = ue;
if ((p = memchr(s, '/', e - s))) {