]> granicus.if.org Git - php/commitdiff
MFH: Fixed bug #24873 (incorrect handling of / inside open_basedir)
authorIlia Alshanetsky <iliaa@php.net>
Wed, 30 Jul 2003 17:55:21 +0000 (17:55 +0000)
committerIlia Alshanetsky <iliaa@php.net>
Wed, 30 Jul 2003 17:55:21 +0000 (17:55 +0000)
main/fopen_wrappers.c

index 759d080bf2245280accb5c5b57239484cf1dedd1..37f96c054d1defa273262330b3d3794aae1a8acd 100644 (file)
@@ -130,19 +130,19 @@ PHPAPI int php_check_specific_open_basedir(const char *basedir, const char *path
 
        /* Resolve the real path into resolved_name */
        if ((expand_filepath(path, resolved_name TSRMLS_CC) != NULL) && (expand_filepath(local_open_basedir, resolved_basedir TSRMLS_CC) != NULL)) {
-               /* Handler for basedirs that end with a / */            
-               if (basedir[strlen(basedir)-1] == PHP_DIR_SEPARATOR) {
-                       resolved_basedir_len = strlen(resolved_basedir);
+               /* Handler for basedirs that end with a / */
+               resolved_basedir_len = strlen(resolved_basedir);
+               if (basedir[strlen(basedir)-1] == PHP_DIR_SEPARATOR && resolved_basedir[resolved_basedir_len -1] != PHP_DIR_SEPARATOR) {
                        resolved_basedir[resolved_basedir_len] = '/';
                        resolved_basedir[++resolved_basedir_len] = '\0';
-               } else {
-                       resolved_basedir_len = strlen(resolved_basedir);        
                }
                
                if (path[strlen(path)-1] == PHP_DIR_SEPARATOR) {
                        resolved_name_len = strlen(resolved_name);
-                       resolved_name[resolved_name_len] = '/';
-                       resolved_name[++resolved_name_len] = '\0';
+                       if (resolved_name[resolved_name_len - 1] != PHP_DIR_SEPARATOR) {
+                               resolved_name[resolved_name_len] = '/';
+                               resolved_name[++resolved_name_len] = '\0';
+                       }
                }
 
                /* Check the path */