iliaa           Wed Dec 20 19:20:22 2006 UTC

  Modified files:              
    /php-src/ext/filter logical_filters.c 
    /php-src/ext/filter/tests   015.phpt 033.phpt 
  Log:
  MFB: Fixed bug #39898 (FILTER_VALIDATE_URL validates \r\n\t etc).
  
  
http://cvs.php.net/viewvc.cgi/php-src/ext/filter/logical_filters.c?r1=1.19&r2=1.20&diff_format=u
Index: php-src/ext/filter/logical_filters.c
diff -u php-src/ext/filter/logical_filters.c:1.19 
php-src/ext/filter/logical_filters.c:1.20
--- php-src/ext/filter/logical_filters.c:1.19   Wed Dec 20 14:37:24 2006
+++ php-src/ext/filter/logical_filters.c        Wed Dec 20 19:20:22 2006
@@ -17,7 +17,7 @@
   +----------------------------------------------------------------------+
 */
 
-/* $Id: logical_filters.c,v 1.19 2006/12/20 14:37:24 derick Exp $ */
+/* $Id: logical_filters.c,v 1.20 2006/12/20 19:20:22 iliaa Exp $ */
 
 #include "php_filter.h"
 #include "filter_private.h"
@@ -481,6 +481,13 @@
 void php_filter_validate_url(PHP_INPUT_FILTER_PARAM_DECL) /* {{{ */
 {
        php_url *url;
+       int old_len = Z_STRLEN_P(value);
+       
+       php_filter_url(value, flags, option_array, charset TSRMLS_DC);
+
+       if (Z_TYPE_P(value) != IS_STRING || old_len != Z_STRLEN_P(value)) {
+               RETURN_VALIDATION_FAILED
+       }
 
        /* Use parse_url - if it returns false, we return NULL */
        url = php_url_parse_ex(Z_STRVAL_P(value), Z_STRLEN_P(value));
@@ -490,10 +497,10 @@
        }
 
        if (
-               ((flags & FILTER_FLAG_SCHEME_REQUIRED) && url->scheme == NULL) 
||
-               ((flags & FILTER_FLAG_HOST_REQUIRED) && url->host == NULL) ||
-               ((flags & FILTER_FLAG_PATH_REQUIRED) && url->path == NULL) ||
-               ((flags & FILTER_FLAG_QUERY_REQUIRED) && url->query == NULL)
+               url->scheme == NULL || 
+               /* some schemas allow the host to be empty */
+               (url->host == NULL && (strcmp(url->scheme, "mailto") && 
strcmp(url->scheme, "news") && strcmp(url->scheme, "file"))) ||
+               ((flags & FILTER_FLAG_PATH_REQUIRED) && url->path == NULL) || 
((flags & FILTER_FLAG_QUERY_REQUIRED) && url->query == NULL)
        ) {
                php_url_free(url);
                RETURN_VALIDATION_FAILED
http://cvs.php.net/viewvc.cgi/php-src/ext/filter/tests/015.phpt?r1=1.8&r2=1.9&diff_format=u
Index: php-src/ext/filter/tests/015.phpt
diff -u php-src/ext/filter/tests/015.phpt:1.8 
php-src/ext/filter/tests/015.phpt:1.9
--- php-src/ext/filter/tests/015.phpt:1.8       Tue Dec 19 14:16:07 2006
+++ php-src/ext/filter/tests/015.phpt   Wed Dec 20 19:20:22 2006
@@ -24,6 +24,10 @@
 '',    
 -1,    
 array(),       
+'mailto:[EMAIL PROTECTED]',
+'news:news.php.net',
+'file://foo/bar',
+"http://\r\n/bar";,
 );
 foreach ($values as $value) {
        var_dump(filter_var($value, FILTER_VALIDATE_URL));
@@ -48,18 +52,22 @@
 string(31) "http://www.example/img/test.png";
 string(27) "http://www.example/img/dir/";
 string(26) "http://www.example/img/dir";
-string(28) "http//www.example/wrong/url/"
-string(17) "http:/www.example"
+bool(false)
+bool(false)
 string(18) "file:///tmp/test.c"
 string(26) "ftp://ftp.example.com/tmp/";
-string(11) "/tmp/test.c"
-string(1) "/"
 bool(false)
-string(6) "http:/"
-string(5) "http:"
-string(4) "http"
-string(0) ""
-string(2) "-1"
+bool(false)
+bool(false)
+bool(false)
+bool(false)
+bool(false)
+bool(false)
+bool(false)
+bool(false)
+string(18) "mailto:[EMAIL PROTECTED]"
+string(17) "news:news.php.net";
+string(14) "file://foo/bar"
 bool(false)
 bool(false)
 string(10) "http://qwe";
@@ -70,4 +78,4 @@
 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
+Done
\ No newline at end of file
http://cvs.php.net/viewvc.cgi/php-src/ext/filter/tests/033.phpt?r1=1.7&r2=1.8&diff_format=u
Index: php-src/ext/filter/tests/033.phpt
diff -u php-src/ext/filter/tests/033.phpt:1.7 
php-src/ext/filter/tests/033.phpt:1.8
--- php-src/ext/filter/tests/033.phpt:1.7       Tue Dec 19 14:16:08 2006
+++ php-src/ext/filter/tests/033.phpt   Wed Dec 20 19:20:22 2006
@@ -11,7 +11,7 @@
 boolean                  1                                                     
                                            
 float                    1                                               123   
                                            
 validate_regexp                                                                
                   O'Henry                  
-validate_url        PHP  1  [EMAIL PROTECTED]    http://a.b.c        1.2.3.4   
123  123abc<>()          O'Henry        하퍼    
+validate_url                               http://a.b.c                        
                                            
 validate_email              [EMAIL PROTECTED]                                  
                                                  
 validate_ip                                                    1.2.3.4         
                                            
 string              PHP  1  [EMAIL PROTECTED]    http://a.b.c        1.2.3.4   
123  123abc()            O&#39;Henry    하퍼    

-- 
PHP CVS Mailing List (http://www.php.net/)
To unsubscribe, visit: http://www.php.net/unsub.php

Reply via email to