How to include PHP files that require an absolute path?
Now, I use those objects in both script.php and /soap/soap.php , I could move them, but I want the directory structure like that for a specific reason. When executing script.php the include path is inc/include.php and when executing /soap/soap.php it’s ../inc , absolute paths work, /mnt/webdev/[project name]/inc/include1.php. But it’s an ugly solution if I ever want to move the directory to a different location. So is there a way to use relative paths, or a way to programmatically generate the «/mnt/webdev/[project name]/» ?
11 Answers 11
$root = realpath($_SERVER["DOCUMENT_ROOT"]); include "$root/inc/include1.php";
Edit: added imporvement by aussieviking
Be careful, this will only ever work if you execute the script via a web server that populates DOCUMENT_ROOT
just a question, why realpath() for $_SERVER[«DOCUMENT_ROOT»]? This shall not output always the canonical path?
You can use relative paths. Try __FILE__ . This is a PHP constant which always returns the path/filename of the script it is in. So, in soap.php , you could do:
include dirname(__FILE__).'/../inc/include.php';
The full path and filename of the file. If used inside an include, the name of the included file is returned. Since PHP 4.0.2, __FILE__ always contains an absolute path with symlinks resolved whereas in older versions it contained relative path under some circumstances. (source)
Another solution would be to set an include path in your httpd.conf or an .htaccess file.
I think you should add a / at the beginning of the quoted expression, to separate the .. from the FILE name.
Note that since PHP 5.3.0 you can use the magic constant __DIR__ rather than having to use dirname(__FILE__) . (PHP docs)
Another way to handle this that removes any need for includes at all is to use the autoload feature. Including everything your script needs «Just in Case» can impede performance. If your includes are all class or interface definitions, and you want to load them only when needed, you can overload the __autoload() function with your own code to find the appropriate class file and load it only when it’s called. Here is the example from the manual:
function __autoload($class_name) < require_once $class_name . '.php'; >$obj = new MyClass1(); $obj2 = new MyClass2();
As long as you set your include_path variables accordingly, you never need to include a class file again.
I think the variable you are looking for is: $_SERVER[«DOCUMENT_ROOT»]
You could define a constant with the path to the root directory of your project, and then put that at the beginning of the path.
Another option, related to Kevin’s, is use __FILE__ , but instead replace the php file name from within it:
I’ve been using this for a while. The only problem is sometimes you don’t have $_SERVER[‘SCRIPT_NAME’] , but sometimes there is another variable similar.
I found this to work very well!
include(findRoot() . 'Post.php'); $posts = getPosts(findRoot() . 'posts_content'); include(findRoot() . 'includes/head.php'); for ($i=(sizeof($posts)-1); 0 displayArticle(); > include(findRoot() . 'includes/footer.php'); ?>
I think the best way is to put your includes in your PHP include path. There are various ways to do this depending on your setup.
Then you can simply refer to
from inside any file regardless of where it is whether in your includes or in your web accessible files, or any level of nested subdirectories.
This allows you to have your include files outside the web server root, which is a best practice.
site directory html (web root) your web-accessible files includes your include files
Also, check out __autoload for lazy loading of class files
require(str_repeat('../',(substr_count(getenv('SCRIPT_URL'),'/')-1))."/path/to/file.php");
I use this line of code. It goes back to the «top» of the site tree, then goes to the file desired.
For example, let’s say i have this file tree:
domain.com/aaa/index.php
domain.com/bbb/ccc/ddd/index.php
domain.com/_resources/functions.php
I can include the functions.php file from wherever i am, just by copy pasting
require(str_repeat('../',(substr_count(getenv('SCRIPT_URL'),'/')-1))."/_resources/functions.php");
If you need to use this code many times, you may create a function that returns the str_repeat(‘../’,(substr_count(getenv(‘SCRIPT_URL’),’/’)-1)) part. Then just insert this function in the first file you include. I have an «initialize.php» file that i include at the very top of each php page and which contains this function. The next time i have to include files, i in fact just use the function (named path_back ):
require(path_back()."/_resources/another_php_file.php");
@Flubba, does this allow me to have folders inside my include directory? flat include directories give me nightmares. as the whole objects directory should be in the inc directory.
Oh yes, absolutely. So for example, we use a single layer of subfolders, generally:
require_once('library/string.class.php')
You need to be careful with relying on the include path too much in really high traffic sites, because php has to hunt through the current directory and then all the directories on the include path in order to see if your file is there and this can slow things up if you’re getting hammered.
So for example if you’re doing MVC, you’d put the path to your application directoy in the include path and then specify refer to things in the form
'model/user.class' 'controllers/front.php'
But generally speaking, it just lets you work with really short paths in your PHP that will work from anywhere and it’s a lot easier to read than all that realpath document root malarkey.
The benefit of those script-based alternatives others have suggested is they work anywhere, even on shared boxes; setting the include path requires a little more thought and effort but as I mentioned lets you start using __autoload which just the coolest.
get_include_path
Gets the current include_path configuration option value.
Parameters
This function has no parameters.
Return Values
Returns the path, as a string, or false on failure.
Examples
Example #1 get_include_path() example
// Or using ini_get()
echo ini_get ( ‘include_path’ );
?>
See Also
- ini_get() — Gets the value of a configuration option
- restore_include_path() — Restores the value of the include_path configuration option
- set_include_path() — Sets the include_path configuration option
- include — include
User Contributed Notes 1 note
If you are trying to find a file on your include path, there is a better way: http://php.net/manual/en/function.stream-resolve-include-path.php
- PHP Options/Info Functions
- assert_options
- assert
- cli_get_process_title
- cli_set_process_title
- dl
- extension_loaded
- gc_collect_cycles
- gc_disable
- gc_enable
- gc_enabled
- gc_mem_caches
- gc_status
- get_cfg_var
- get_current_user
- get_defined_constants
- get_extension_funcs
- get_include_path
- get_included_files
- get_loaded_extensions
- get_required_files
- get_resources
- getenv
- getlastmod
- getmygid
- getmyinode
- getmypid
- getmyuid
- getopt
- getrusage
- ini_alter
- ini_get_all
- ini_get
- ini_parse_quantity
- ini_restore
- ini_set
- memory_get_peak_usage
- memory_get_usage
- memory_reset_peak_usage
- php_ini_loaded_file
- php_ini_scanned_files
- php_sapi_name
- php_uname
- phpcredits
- phpinfo
- phpversion
- putenv
- set_include_path
- set_time_limit
- sys_get_temp_dir
- version_compare
- zend_thread_id
- zend_version
- get_magic_quotes_gpc
- get_magic_quotes_runtime
- restore_include_path
PHP, How to set include path
If I have many files in there, how do I access these files without having to include each individually? Setting the environmental variable definitely works in the command prompt.
Do I need to do something else for .php files to be accessible collectively under a directory?
7 Answers 7
Common practice is to have a «common.php» or «includes.php» file that includes the include / include_once calls (for the sake of simplicity). e.g.
Then includes.php contains:
Then in any script it’s a matter of including the includes.php file.
However, to answer your original question, you can only include one file at a time, per call. You can use something like opendir and readdir to iterate over all files in a specific directory and include them as found (automated so-to-speak) or write out each include yourself based on the files you’re creating.
Also, all setting the include path does is set a directory to look in when an include call is made. It’s not a directory where the files should automatically be loaded (which is the impression I get from your post).
Hmph!! it’s all clear to me now. Thanks for showing me the common way. I’m still trying to figure out what’s «conventional» in PHP.
If this is your own personal project, «conventional» is whatever way works for you. The moment you have to start using the find function(s) or write file names down with notes you’re losing sight of «conventional». 😉
if I include «include.php» that loads up a bunch of .php files (say twenty ~50-line functions) that I may or may not need, would this impose some kind of unnecessary load when running the script that include these? I’m wondering if I should customize my include.php or just make 1 that includes all of my functions.
@user: Depends. Maybe make a «common.php» that has functions used on 90% of the pages, then a «user_includes.php» with user functions only used on member pages, etc. Go download phpBB and look how they set their structure up, that should give you some good insight on how to proceed.
Setting the include_path will not include every file in that directory, it only adds that directory to the list PHP will search when including a file.
Specifies a list of directories where the require(), include(), fopen(), file(), readfile() and file_get_contents() functions look for files.
This would simplify including files in a deep structure or in a completely different section of the filesystem.
include('/var/somewhere/else/foo.php');
With /var/somewhere/else/ added to the php.ini include_path could become
Additionally, as others pointed out, there are common practices but you could look into OOPHP and autoloading classes. This will not work for functions that I know of.
Many developers writing object-oriented applications create one PHP source file per-class definition. One of the biggest annoyances is having to write a long list of needed includes at the beginning of each script (one for each class).
In PHP 5, this is no longer necessary. You may define an __autoload function which is automatically called in case you are trying to use a class/interface which hasn’t been defined yet. By calling this function the scripting engine is given a last chance to load the class before PHP fails with an error.