diff options
Diffstat (limited to 'ext')
| -rw-r--r-- | ext/filter/tests/015.phpt | 2 | ||||
| -rw-r--r-- | ext/standard/url.c | 16 |
2 files changed, 16 insertions, 2 deletions
diff --git a/ext/filter/tests/015.phpt b/ext/filter/tests/015.phpt index a9c4a8cf48..7be849e76c 100644 --- a/ext/filter/tests/015.phpt +++ b/ext/filter/tests/015.phpt @@ -28,6 +28,7 @@ array(), 'news:news.php.net', 'file://foo/bar', "http://\r\n/bar", +"http://example.com:qq" ); foreach ($values as $value) { var_dump(filter_var($value, FILTER_VALIDATE_URL)); @@ -70,6 +71,7 @@ string(17) "news:news.php.net" string(14) "file://foo/bar" bool(false) bool(false) +bool(false) string(10) "http://qwe" bool(false) bool(false) diff --git a/ext/standard/url.c b/ext/standard/url.c index 2e29c9dd4d..00f5694e07 100644 --- a/ext/standard/url.c +++ b/ext/standard/url.c @@ -180,15 +180,20 @@ PHPAPI php_url *php_url_parse_ex(char const *str, int length) parse_port: p = e + 1; pp = p; - + while (pp-p < 6 && isdigit(*pp)) { pp++; } - + if (pp-p < 6 && (*pp == '/' || *pp == '\0')) { memcpy(port_buf, p, (pp-p)); port_buf[pp-p] = '\0'; ret->port = atoi(port_buf); + if (!ret->port && (pp - p) > 0) { + STR_FREE(ret->scheme); + efree(ret); + return NULL; + } } else { goto just_path; } @@ -267,6 +272,13 @@ PHPAPI php_url *php_url_parse_ex(char const *str, int length) memcpy(port_buf, p, (e-p)); port_buf[e-p] = '\0'; ret->port = atoi(port_buf); + if (!ret->port && (e - p)) { + STR_FREE(ret->scheme); + STR_FREE(ret->user); + STR_FREE(ret->pass); + efree(ret); + return NULL; + } } p--; } |
