|  support |  documentation |  report a bug |  advanced search |  search howto |  statistics |  random bug |  login
Bug #41492 open_basedir bypass via readfile()
Submitted: 2007-05-24 15:55 UTC Modified: 2007-05-27 17:33 UTC
From: bugs dot php dot net at chsc dot dk Assigned:
Status: Closed Package: Safe Mode/open_basedir
PHP Version: 5.2.2 OS: Linux
Private report: No CVE-ID:
 [2007-05-24 15:55 UTC] bugs dot php dot net at chsc dot dk
file_exists() etc. does not allow checking the existence of files outside the directories specified in open_basedir.

Appearently readfile() does *not* have this restriction and thus allows checking the existence of files anywhere in the filesystem. If realpath($filename) returns a string (i.e. not false), the file exists. This is a circumvention of the open_basedir restriction in file_exists() etc.

Reproduce code:
The following should always be true, but it isn't when $dir is outside the directories specified in open_basedir:

var_dump(file_exists($dir) === (bool) realpath($dir));


Add a Patch

Pull Requests

Add a Pull Request


AllCommentsChangesGit/SVN commitsRelated reports
 [2007-05-27 17:33 UTC]
This bug has been fixed in CVS.

Snapshots of the sources are packaged every three hours; this change
will be in the next snapshot. You can grab the snapshot at
Thank you for the report, and for helping us make PHP better.

PHP Copyright © 2001-2015 The PHP Group
All rights reserved.
Last updated: Sun Nov 29 01:01:35 2015 UTC