Edit report at https://bugs.php.net/bug.php?id=51642&edit=1
ID: 51642
Updated by: ras...@php.net
Reported by: graham at grahamweldon dot com
Summary: FILTER_VALIDATE_URL should fail if an invalid IP
address is used
Status: Open
-Type: Documentation Problem
+Type: Feature/Change Request
Package: Filter related
Operating System: OSX 10.5.3
PHP Version: 5.2.13
Block user comment: N
Private report: N
New Comment:
I'll put it back to a feature request. I do agree it would be useful to have an
RFC3986 validator. This code was written prior to that RFC. RFC2396 doesn't
specify validating the dotted-decimal IPv4 syntax, but RFC3986 does along with
introducing IPv6-support, of course.
Previous Comments:
------------------------------------------------------------------------
[2012-02-15 01:26:14] graham at grahamweldon dot com
I think it becomes a documentation issue, if the request to add IP validation
as
part of the FILTER_VALIDATE_URL is declined.
------------------------------------------------------------------------
[2012-02-15 00:07:41] ras...@php.net
This is more of a documentation issue than an actual feature request.
------------------------------------------------------------------------
[2012-02-14 22:22:10] hairmare at purplehaze dot ch
FILTER_VALIDATE_URL implements RFC2396 (which does not even mention ip
validation). Have you considered ANDing FILTER_VALIDATE_URL with
FILTER_VALIDATE_IP like so:
<?php
$url = 'http://999.123.999.123';
var_dump(
filter_var($url, FILTER_VALIDATE_URL) &&
filter_var(parse_url($url, PHP_URL_HOST), FILTER_VALIDATE_IP)
);
------------------------------------------------------------------------
[2010-04-26 03:08:50] graham at grahamweldon dot com
Fixed OSX Veron number in report.
------------------------------------------------------------------------
[2010-04-23 09:48:52] graham at grahamweldon dot com
Description:
------------
Tested using PHP 5.2.13 and PHP 5.3.1
Supply of an invalid IP address as the host part of a URL passes the filter_var
validation.
I propose that validation should fail if an invalid IP address is provided in
URL
validation.
Test script:
---------------
var_dump(filter_var('http://999.123.999.123', FILTER_VALIDATE_URL));
Expected result:
----------------
bool(false)
Actual result:
--------------
string(22) "http://999.123.999.123"
------------------------------------------------------------------------
--
Edit this bug report at https://bugs.php.net/bug.php?id=51642&edit=1