Web server directory index
When an
A common filename for such a page is index.
default.asp
) even though it may be more appropriate to still specify the HTML output (index.html.php
or index.html.aspx
), as this should not be taken for granted. An example is the popular open source web server Apache, where the list of filenames is controlled by the DirectoryIndex
[1] directive in the main server configuration file or in the configuration file for that directory. It is possible to not use file extensions at all, and be neutral to content delivery methods, and set the server to automatically pick the best file through content negotiation
If the server is unable to find a file with any of the names listed in its configuration, it may either return an error (usually
autoindex
, is also configurable.[2]History
A scheme where web server serves a default file on per-subdirectory basis has been supported as early as
Welcome.html
and welcome.html
in addition to the NCSA-originated index.html
.[5]Later web servers typically support this default file scheme in one form or another; this is usually configurable, with index.html
being one of the default file names.[6][7][8]
Implementation
In some cases, the home page of a website can be a menu of language options for large sites that use geotargeting. It is also possible to avoid this step, for example, by using content negotiation.
In cases where no known index.*
file exists within a given directory, the web server may be configured to provide an automatically generated listing of the files within the directory instead. With the Apache web server, for example, this behavior is provided by the mod_autoindex module[9] and controlled by the Options +Indexes
directive[10] in the web server configuration files. These automated directory listings are sometimes a security risk because they enumerate sensitive files which may not be intended for public access, in a process known as a directory indexing attack.[11] Such a security misconfiguration[12] may also assist in other attacks, such as a path or directory traversal attack.[13]
Performances
When accessing a directory, the various available index methods may also have a different impact on usage of OS resources (
Proceeding from fastest to slowest method, here is the list:
- using a static index file, e.g.:
index.html
, etc.; - using a web server feature usually named autoindex (when no index file exists) to let web server autogenerate directory listing by using its internal module;
- using an interpreted file read by web server internal program interpreter, e.g.:
index.php
; - using a CGI executable and compiled program, e.g.:
index.cgi
.
References
- ^ "mod_dir - Apache HTTP Server". httpd.apache.org. Retrieved 2014-05-30.
- ^ ASF Infrabot (2019-05-22). "Directory listings". Apache foundation: HTTPd server project. Retrieved 2021-11-16.
- ^ a b "WWW-Talk Apr-Jun 1993: NCSA httpd version 0.3". 1997.webhistory.org.
- ^ "NCSA HTTPd DirectoryIndex". January 31, 2009. Archived from the original on January 31, 2009.
- ^ "Change History of W3C httpd". June 5, 1997. Archived from the original on June 5, 1997.
- ^ "mod_dir - Apache HTTP Server Version 2.4 § DirectoryIndex Directive". httpd.apache.org. Archived from the original on 2020-11-12. Retrieved 2021-01-13.
- ^ "NGINX Docs | Serving Static Content". docs.nginx.com. Archived from the original on 2020-11-11. Retrieved 2021-01-13.
- ^ "Default Document <defaultDocument> | Microsoft Docs". docs.microsoft.com. Archived from the original on 2020-12-08. Retrieved 2021-01-13.
- ^ "mod_autoindex - Apache HTTP Server Version 2.4". httpd.apache.org. Retrieved 2021-01-13.
- ^ "core - Apache HTTP Server Version 2.4 § Options Directive". httpd.apache.org. Retrieved 2021-01-13.
- ^ "IBM Docs". IBM. 2021-03-08. Retrieved 2021-05-07.
- ^ "A6:2017-Security Misconfiguration". OWASP. Retrieved 2021-05-07.
- ^ "Path Traversal". OWASP. Retrieved 2021-05-07.