<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>Bruce &#187; Robots</title>
	<atom:link href="http://brucehan.com/archives/tag/robots/feed" rel="self" type="application/rss+xml" />
	<link>http://brucehan.com</link>
	<description>Something of a professional cynic.</description>
	<lastBuildDate>Sun, 04 Mar 2012 13:33:29 +0000</lastBuildDate>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
	<generator>http://wordpress.org/?v=3.3.1</generator>
		<item>
		<title>Robots.txt</title>
		<link>http://brucehan.com/archives/711</link>
		<comments>http://brucehan.com/archives/711#comments</comments>
		<pubDate>Fri, 14 Aug 2009 08:15:08 +0000</pubDate>
		<dc:creator>Bruce</dc:creator>
				<category><![CDATA[Seo]]></category>
		<category><![CDATA[Baidu]]></category>
		<category><![CDATA[Google]]></category>
		<category><![CDATA[Robots]]></category>

		<guid isPermaLink="false">http://brucehan.com/archives/711</guid>
		<description><![CDATA[什么是robots.txt？ robots.txt是一个纯文本文件，在这个文件中网站管理者可以声明该网站中不想被robots访问的部分，或者指定搜索引擎只收录指定的内容。 robots.txt是搜索引擎中访问网站的时候要查看的第一个文件。Robots.txt文件告诉蜘蛛程序在服务器上什么文件是可以被查看的。 当一个搜索蜘蛛访问一个站点时，它会首先检查该站点根目录下是否存在robots.txt，如果存在，搜索机器人就会按照该文件中的内容来确定访问的范围；如果该文件不存在，所有的搜索蜘蛛将能够访问网站上所有没有被口令保护的页面。 robots.txt必须放置在一个站点的根目录下，而且文件名必须全部小写。 语法： 最简单的 robots.txt 文件使用两条规则： User-Agent: 适用下列规则的漫游器 Disallow: 要拦截的网页 robots.txt使用误区 误区一：我的网站上的所有文件都需要蜘蛛抓取，那我就没必要在添加robots.txt文件了。反正如果该文件不存在，所有的搜索蜘蛛将默认能够访问网站上所有没有被口令保护的页面。 每当用户试图访问某个不存在的URL时，服务器都会在日志中记录404错误（无法找到文件）。每当搜索蜘蛛来寻找并不存在的robots.txt文件时，服务器也将在日志中记录一条404错误，所以你应该做网站中添加一个robots.txt。 误区二：在robots.txt文件中设置所有的文件都可以被搜索蜘蛛抓取，这样可以增加网站的收录率。 网站中的程序脚本、样式表等文件即使被蜘蛛收录，也不会增加网站的收录率，还只会浪费服务器资源。因此必须在robots.txt文件里设置不要让搜索蜘蛛索引这些文件。 网站管理员必须使蜘蛛程序远离某些服务器上的目录——保证服务器性能。比如：大多数网站服务器都有程序储存在“cgi-bin”目录下，因此在 robots.txt文件中加入“Disallow: /cgi-bin”是个好主意，这样能够避免将所有程序文件被蜘蛛索引，可以节省服务器资源。一般网站中不需要蜘蛛抓取的文件有：后台管理文件、程序脚本、附件、数据库文件、编码文件、样式表文件、模板文件、导航图片和背景图片等等。 下面是VeryCMS里的robots.txt文件： User-agent: * Disallow: /admin/ 后台管理文件 Disallow: /require/ 程序文件 Disallow: /attachment/ 附件 Disallow: /images/ 图片 Disallow: /data/ 数据库文件 Disallow: /template/ 模板文件 Disallow: /css/ 样式表文件 Disallow: /lang/ 编码文件 Disallow: /script/ 脚本文件 误区三：搜索蜘蛛抓取网页太浪费服务器资源，在robots.txt文件设置所有的搜索蜘蛛都不能抓取全部的网页。 如果这样的话，会导致整个网站不能被搜索引擎收录。 robots.txt使用范例: 1、如果你的网站是动态网页，并且你为这些动态网页创建了静态副本，以供搜索蜘蛛更容易抓取。那么你需要在robots.txt文件里设置避免动态网页被蜘蛛索引，以保证这些网页不会被视为含重复内容。 [...]]]></description>
			<content:encoded><![CDATA[<p><strong>什么是<a href="http://brucehan.com/archives/711"title="SEO中机器人的写法相关！" >robots</a>.txt</strong>？</p>
<p>robots.txt是一个纯文本文件，在这个文件中网站管理者可以<a href="http://brucehan.com/archives/220"title="博客原创声明！" >声明</a>该网站中不想被robots访问的部分，或者指定<a href="http://brucehan.com/archives/288"target="_blank"title="搜索引擎的定义！" >搜索引擎</a>只<a href="http://brucehan.com/archives/59"title="收录是男人的梦想！" >收录</a>指定的内容。</p>
<p>robots.txt是搜索引擎中访问网站的时候要查看的第一个文件。Robots.txt文件告诉<a href="http://brucehan.com/archives/289"target="_blank"title="Spider" >蜘蛛</a>程序在服务器上什么文件是可以被查看的。</p>
<p>当一个搜索蜘蛛访问一个站点时，它会首先检查该站点根目录下是否存在robots.txt，如果存在，搜索机器人就会按照该文件中的内容来确定访问的范围；如果该文件不存在，所有的搜索蜘蛛将能够访问网站上所有没有被口令保护的页面。</p>
<p><span style="color: #ff0000;">robots.txt必须放置在一个站点的根目录下，而且文件名必须全部小写</span>。</p>
<p><strong>语法：</strong></p>
<p>最简单的 robots.txt 文件使用两条规则：</p>
<p>User-Agent: 适用下列规则的漫游器</p>
<p>Disallow: 要拦截的网页</p>
<p><strong>robots.txt使用误区</strong></p>
<p><span id="more-711"></span></p>
<p>误区一：我的网站上的所有文件都需要蜘蛛<a href="http://brucehan.com/archives/290"title="目标是全收录！" >抓取</a>，那我就没必要在添加robots.txt文件了。反正如果该文件不存在，所有的搜索蜘蛛将默认能够访问网站上所有没有被口令保护的页面。</p>
<p>每当用户试图访问某个不存在的URL时，服务器都会在日志中记录404错误（无法找到文件）。每当搜索蜘蛛来寻找并不存在的robots.txt文件时，服务器也将在日志中记录一条404错误，所以你应该做网站中添加一个robots.txt。</p>
<p>误区二：在robots.txt文件中设置所有的文件都可以被搜索蜘蛛抓取，这样可以增加网站的收录率。</p>
<p>网站中的程序<a href="http://brucehan.com/archives/1016"title="系统清理脚本！" >脚本</a>、样式表等文件即使被蜘蛛收录，也不会增加网站的收录率，还只会浪费服务器资源。因此必须在robots.txt文件里设置不要让搜索蜘蛛索引这些文件。</p>
<p>网站管理员必须使蜘蛛程序远离某些服务器上的目录——保证服务器性能。比如：大多数网站服务器都有程序储存在“cgi-bin”目录下，因此在 robots.txt文件中加入“Disallow: /cgi-bin”是个好主意，这样能够避免将所有程序文件被蜘蛛索引，可以节省服务器资源。一般网站中不需要蜘蛛抓取的文件有：后台管理文件、程序脚本、附件、<a href="http://brucehan.com/archives/797"title="PHP+Mysql数据库连接范例！" >数据库</a>文件、编码文件、样式表文件、模板文件、导航图片和背景图片等等。</p>
<p>下面是Very<a href="http://brucehan.com/archives/98"title="主要是说kingcms" >CMS</a>里的robots.txt文件：</p>
<p>User-agent: *</p>
<p>Disallow: /admin/ 后台管理文件</p>
<p>Disallow: /require/ 程序文件</p>
<p>Disallow: /attachment/ 附件</p>
<p>Disallow: /images/ 图片</p>
<p>Disallow: /data/ 数据库文件</p>
<p>Disallow: /template/ 模板文件</p>
<p>Disallow: /<a href="http://brucehan.com/archives/466"title="CSS" >css</a>/ 样式表文件</p>
<p>Disallow: /lang/ 编码文件</p>
<p>Disallow: /script/ 脚本文件</p>
<p>误区三：搜索蜘蛛抓取网页太浪费服务器资源，在robots.txt文件设置所有的搜索蜘蛛都不能抓取全部的网页。</p>
<p>如果这样的话，会导致整个网站不能被搜索引擎收录。</p>
<p><strong>robots.txt使用范例:</strong></p>
<p>1、如果你的网站是动态网页，并且你为这些动态网页创建了静态副本，以供搜索蜘蛛更容易抓取。那么你需要在robots.txt文件里设置避免动态网页被蜘蛛索引，以保证这些网页不会被视为含重复内容。</p>
<p>2、合理使用robots.txt文件还能避免访问时出错。比如，不能让搜索者直接进入购物车页面。因为没有理由使购物车被收录，所以你可以在robots.txt文件里设置来阻止搜索者直接进入购物车页面。</p>
<p>3、robots.txt文件里还可以直接包括在sitemap文件的链接。就像这样：</p>
<p>Sitemap: sitemap.xml</p>
<p>目前对此表示支持的搜索引擎公司有Google, Yahoo, Ask and MSN。而中文搜索引擎公司，显然不在这个圈子内。这样做的好处就是，站长不用到每个搜索引擎的站长工具或者相似的站长部分，去提交自己的sitemap文件，搜索引擎的蜘蛛自己就会抓取robots.txt文件，读取其中的sitemap路径，接着抓取其中相链接的网页。</p>
<p>4、允许所有的robot访问</p>
<p><em>User-agent: *<br />
Disallow:</em></p>
<p>或者也可以建一个空文件 &#8220;/robots.txt&#8221; file</p>
<p>禁止所有搜索引擎访问网站的任何部分</p>
<p><em>User-agent: *<br />
Disallow: /</em></p>
<p>禁止所有搜索引擎访问网站的几个部分（下例中的01、02、03目录）</p>
<p>User-agent: *<br />
Disallow: /01/<br />
Disallow: /02/<br />
Disallow: /03/</p>
<p>禁止某个搜索引擎的访问（下例中的BadBot）</p>
<p><em>User-agent: BadBot<br />
Disallow: /</em></p>
<p>只允许某个搜索引擎的访问（下例中的Crawler）</p>
<p><em>User-agent: Crawler<br />
Disallow:</em></p>
<p><em>User-agent: *<br />
Disallow: /</em></p>
<p>另外，我觉得有必要进行拓展说明，对robots <a href="http://brucehan.com/archives/1229"title="Meta" >meta</a>进行一些介绍：</p>
<p>Robots META标签则主要是针对一个个具体的页面。和其他的META标签（如使用的语言、页面的描述、关键词等）一样，Robots META标签也是放在页面的＜head＞＜/head＞中，专门用来告诉搜索引擎ROBOTS如何抓取该页的内容。</p>
<p>Robots META标签的写法：</p>
<p>Robots META标签中没有大小写之分，name=”Robots”表示所有的搜索引擎，可以针对某个具体搜索引擎写为name=”BaiduSpider”。 content部分有四个指令选项：index、noindex、follow、<a href="http://brucehan.com/archives/230"target="_blank"title="Nofollow标签的前世今生" >nofollow</a>，指令间以“,”分隔。</p>
<p>INDEX 指令告诉搜索机器人抓取该页面；</p>
<p>FOLLOW 指令表示搜索机器人可以沿着该页面上的链接继续抓取下去；</p>
<p>Robots Meta标签的缺省值是INDEX和FOLLOW，只有inktomi除外，对于它，缺省值是INDEX,NOFOLLOW。</p>
<p>这样，一共有四种组合：</p>
<p>＜META NAME=&#8221;ROBOTS&#8221; CONTENT=&#8221;INDEX,FOLLOW&#8221;＞<br />
＜META NAME=&#8221;ROBOTS&#8221; CONTENT=&#8221;NOINDEX,FOLLOW&#8221;＞<br />
＜META NAME=&#8221;ROBOTS&#8221; CONTENT=&#8221;INDEX,NOFOLLOW&#8221;＞<br />
＜META NAME=&#8221;ROBOTS&#8221; CONTENT=&#8221;NOINDEX,NOFOLLOW&#8221;＞</p>
<p>其中</p>
<p>＜META NAME=&#8221;ROBOTS&#8221; CONTENT=&#8221;INDEX,FOLLOW&#8221;＞可以写成＜META NAME=&#8221;ROBOTS&#8221; CONTENT=&#8221;ALL&#8221;＞；</p>
<p>＜META NAME=&#8221;ROBOTS&#8221; CONTENT=&#8221;NOINDEX,NOFOLLOW&#8221;＞可以写成＜META NAME=&#8221;ROBOTS&#8221; CONTENT=&#8221;NONE&#8221;＞</p>
<p>目前看来，绝大多数的搜索引擎机器人都遵守robots.txt的规则，而对于Robots META标签，目前支持的并不多，但是正在逐渐增加，如著名搜索引擎GOOGLE就完全支持，而且GOOGLE还增加了一个指令“archive”，可以限制GOOGLE是否保留网页快照。例如：</p>
<p>＜META NAME=&#8221;googlebot&#8221; CONTENT=&#8221;index,follow,noarchive&#8221;＞</p>
<p>表示抓取该站点中页面并沿着页面中链接抓取，但是不在GOOLGE上保留该页面的网页快照。</p>
<p><script type="text/javascript"><!--
google_ad_client = "pub-5736529044108483";
/* 468x60, 创建于 11-9-6 */
google_ad_slot = "7344821931";
google_ad_width = 468;
google_ad_height = 60;
//-->
</script>
<script type="text/javascript"
src="http://pagead2.googlesyndication.com/pagead/show_ads.js">
</script></p> ]]></content:encoded>
			<wfw:commentRss>http://brucehan.com/archives/711/feed</wfw:commentRss>
		<slash:comments>6</slash:comments>
		</item>
	</channel>
</rss>

