Robots.txt
The robots exclusion standard or robots.txt protocol is a convention to prevent cooperating web spiders and other web robots from accessing all or part of a website. The information specifying the parts that should not be accessed is specified in a file called robots.txt in the top-level directory of the website.
The robots.txt protocol was created by consensus in June 1994 by members of the robots mailing list (robots-request@nexor.co.uk). There is no official standards body or RFC for the protocol.
The protocol is purely advisory. It relies on the cooperation of the web robot, so that marking an area of your site out of bounds with robots.txt does not guarantee privacy. Many web site administrators have been caught trying to use the robots file to make private parts of a website invisible to the rest of the world. However, the file is necessarily publicly available and is easily checked by anyone with a web browser.
The robots.txt patterns are matched by simple substring comparisons, so care should be taken to make sure that patterns matching directories have the final '/' character appended: otherwise all files with names starting with that substring will match, rather than just those in the directory intended.
Examples
This example allows all robots to visit all files because the wildcard "*" specifies all robots.
User-agent: * Disallow:
This example keeps all robots out:
User-agent: * Disallow: /
The next is an example that tells all crawlers not to enter into four directories of a website:
User-agent: * Disallow: /cgi-bin/ Disallow: /images/ Disallow: /tmp/ Disallow: /private/
Example that tells a specific crawler not to enter one specific directory:
User-agent: BadBot Disallow: /private/
Compatability
In order to prevent access to all pages by robots,
Disallow: *
is not appropriate as this is not a stable standard extension. For example, despite the fact that Google claims support for this tag[1], it in fact does not[2].
Instead:
Disallow: /
should be used.
Alternatives
robots.txt is older and more widely accepted, but there are other methods (which can be used together with robots.txt) that allow greater control, like disabling indexing of images only or disabling archiving of page contents.
HTML meta tags for robots
HTML meta tags can be used to exclude robots according to the contents of web pages. Again, this is purely advisory, and also relies on the cooperation of the robot programs. For example,
<meta name="robots" content="noindex,nofollow" />
within the HEAD
section of an HTML document tells search engines such as Google, Yahoo!, or MSN to exclude the page from its index and not to follow any links on this page for further possible indexing.
(See HTML Author's Guide to the Robots META tag.)
Directives within a page
The <NOINDEX> tag is a non-standard HTML tag whose intent is to indicate portions of a page that should not be indexed, such as common navigation or footer. Using it without a namespace will make XHTML pages invalid.
Google uses comments for the same purpose: <!--googleoff: index--> ... <!--googleon: index-->
References
See also
External links
- The robots.txt of the US White House
- How to keep bad robots, spiders and web crawlers away
- robots.txt File (tutorial on how and why to add a robots.txt file to websites, July 19, 2004)
- List of Bad Bots: A short list of bad spiders and nasty bots seen on my different web sites
- HOWTO: Serving up default favicon.ico and robots.txt files with Apache
- Robots.txt Checker (validates robots.txt files and gives optimization tips)
- A Standard for Robot Exclusion
- Robots Exclusion
- Robots.txt Online Generator
- RoboGen - Shareware Windows program for creating and editing robot exclusion files
- White House site has oddities, like Bush site, Nick Farrell (October 29, 2004)
- Comprehensive Robots.txt Tutorial
- Using Robots.txt To Manage Search Engine Spiders