'news:news.php.net',
'file://foo/bar',
"http://\r\n/bar",
-"http://example.com:qq"
+"http://example.com:qq",
+"http://example.com:-2",
+"http://example.com:65536",
+"http://example.com:65537",
);
foreach ($values as $value) {
var_dump(filter_var($value, FILTER_VALIDATE_URL));
bool(false)
bool(false)
bool(false)
+bool(false)
+bool(false)
+bool(false)
string(10) "http://qwe"
bool(false)
bool(false)
string(42) "http://www.example.com/path/at/the/server/"
bool(false)
string(40) "http://www.example.com/index.php?a=b&c=d"
-Done
\ No newline at end of file
+Done
}
}
}
- } else if (e) { /* no scheme, look for port */
+ } else if (e) { /* no scheme; starts with colon: look for port */
parse_port:
p = e + 1;
pp = p;
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) {
+ if (pp - p > 0 && pp - p < 6 && (*pp == '/' || *pp == '\0')) {
+ long port;
+ memcpy(port_buf, p, (pp - p));
+ port_buf[pp - p] = '\0';
+ port = strtol(port_buf, NULL, 10);
+ if (port > 0 && port <= 65535) {
+ ret->port = (unsigned short) port;
+ } else {
STR_FREE(ret->scheme);
efree(ret);
return NULL;
efree(ret);
return NULL;
} else if (e - p > 0) {
- memcpy(port_buf, p, (e-p));
- port_buf[e-p] = '\0';
- ret->port = atoi(port_buf);
- if (!ret->port && (e - p)) {
+ long port;
+ memcpy(port_buf, p, (e - p));
+ port_buf[e - p] = '\0';
+ port = strtol(port_buf, NULL, 10);
+ if (port > 0 && port <= 65535) {
+ ret->port = (unsigned short)port;
+ } else {
STR_FREE(ret->scheme);
STR_FREE(ret->user);
STR_FREE(ret->pass);