从URL静态化与动态化之争谈搜索引擎优化技术(SEO)的学习

(编辑:jimmy 日期: 2025/1/20 浏览:2)

今天在IT茶馆看到一张叫作SEO大局观的图,我在回复里只大了五个字,很好很强大。然后,接下来就开始有点担心了,担心很多看到这张图的朋友会把这当成一个公式或法则来学习和运用。Lonmen想,这张图的作者也应当不愿意看到这查的结果吧!SEO技术一定是发展与实践结合的产物,而不是其它的一层不变的东西,在学习的前辈经验的时候一定不能一味去继承,而是要在实践的基础上多思考和创新。

上面的话,仿乎有夸夸其谈之闲,那我们来说一个具体的案例。如果,我现在说搜索引擎对动态的URL不够友好,URL静态化对SEO非常重要,可能没有几个朋友会反对吧。放眼当下互联网上URL静态化的趋势,应当是可以用越演越烈来形容的。甚至有些站长为了网站的静态化,把自己弄得焦头烂额(当然我不是说,所有的URL静态化都是为了搜索引擎啊)。那么实际的情况是怎样的呢?首先,我们来深入一下案例的主题:
从URL静态化与动态化之争谈搜索引擎优化技术(SEO)的学习 引用内容
什么是静态网址?
一个静态网址,顾名思义,就是一个不会发生变化的网址,它通常不包含任何网址参数。例如:http://www.example.com/archive/january.htm。您可以在搜索框里输入 filetype:html 在谷歌上搜索静态网址。更新此种类型网址的页面会比较耗费时间,尤其是当信息量增长很快时,因为每一个单独的页面都必须更改编译代码。这也是为什么网站管理员们在处理大型的、经常更新的网站,像在线购物网站、论坛社区、博客或者是内容管理系统时,会使用动态网址的原因。

什么是动态网址?
如果一个网站的内容存储于一个数据库,并且根据要求来显示页面,这时就可以使用动态网址。在这种情况下,网站提供的内容基本上是基于模板形式的。通常情况下,一个动态网址看起来像这样:http://code.google.com/p/google-checkout-php-sample-code/issues/detail?id=31。您可以通过寻找像? = & 这样的符号识别出动态网址。动态网址有一个缺陷是不同的网址可以拥有相同的内容。这样导致不同的用户可能链向含有不同参数的网址,但是这些网址却都含有相同的内容。这也是为什么网络管理员有时候想要将这些动态网址重写成静态网址的原因之一。


下面就我们的答案,GOOGLE管理员关于URL的最新(貌似时间也不短了)解答:

我是不是应该让我的动态网址看起来是静态的呢?
在处理动态网址时,希望您能了解以下几点事实:
1、要正确地生成和维护从动态网址到静态化网址的重写转变实际上是一件很难的事情。
2、将原始的动态网址提供给我们会比较安全,请让我们来处理诸如探测和避开那些有问题的参数的事情。
3、如果您想重写网址,请去掉那些不必要的参数,同时请保持它动态网址的样子。
4、如果您想提供一个静态网址代替动态网址,那么您应该切实地生成相应的静态内容。

静态和动态网址,Googlebot 对于哪一个识别得更好呢?
我们碰到过很多网站管理员,像我们的朋友那样,认为静态或者看起来是静态的网址对于网站的索引和排名是有优势的。这种看法是基于这样一个假设,即认为搜索引擎在抓取和分析含有会话标识 (session ID) 和来源追踪器 (source tracker) 的网址时是有问题的。然而,事实是,谷歌在这两个方面都有了相当的进展。就点击率来说,静态网址可能略微有些优势,因为用户可以很容易地读懂这个网址。但是,就索引和排名来说,使用数据库驱动网站并不意味着明显的劣势。相比较将参数隐藏以使他们看起来是静态的网址来说,我们更希望网站将动态的网址直接提供给搜索引擎。

现在,让我们来看一些有关动态网址的广为传播的看法,并且来纠正一些蒙蔽网站管理员的假说。:)

传说:"动态网址不能被抓取。"
事实:我们可以抓取动态网址并且解释不同的参数。如果您为了让网址看起来像是静态的,而隐藏那些可以给谷歌提供有价值信息的参数,这样做反而会给该网址的抓取和排名带来麻烦。我们的建议是:请不要将一个动态网址改换格式以使其看起来是静态的。尽可能地使用静态网址来显示静态内容是可取的,但在您决定展示动态内容的情况下,请不要将参数隐藏起来从而使他们看起来像是静态的,因为这样做会删除掉那些有助于我们分析网址的有用信息。

传说:"动态网址的参数要少于3个。"
事实:对于参数的数量是没有限制的。但是,一个好的经验是不要让您的网址太长(这个适用于所有的网址,不论是静态的还是动态的)。您可以去掉一些对于 Googlebot 来说不重要的参数,给用户一个好看一点的动态网址。如果您不能确定可以去掉哪些参数,我们建议您将动态网址中所有的参数都提供给我们,我们的系统会弄明白哪一些是不重要的。将参数隐藏起来会影响我们正确地分析您的网址,我们也就不能识别这些参数,一些重要信息可能也因此丢失了。

下面一些是我们认为您可能会存在疑问的一些问题。

这是否意味着我应该完全避免重写动态网址?
这是我们的建议,除非您能确保您只是去掉多余的参数,或能够把所有有可能有不良影响的参数完整地删除。如果您把自己的动态网址任意修改使其看起来像是静态的,您要清楚这样做是有风险的,有可能会导致有些信息不能被正常地编译和识别。如果您想给您的网站再增加一个静态的版本,请您一定要提供一个真正意义上的静态的内容,比如生成那些可以通过网站相应路径而获取的文件。如果您仅仅是修改了动态网址的表现形式,而没有真正提供静态的内容,那么您有可能适得其反。请直接把标准的动态URL提供给我们,我们会自动找出那些冗余的参数。

你能给我举一个例子么?
如果您有一个像下面这样标准格式的动态网址:foo?key1=value&key2=value2,我们建议您不用改动它,谷歌会决定哪些参数可以去掉;或者您可以为用户去掉那些不必要的参数。不过要慎重,仅仅去掉那些不重要的参数。这里有一个含有多个参数的动态网址的例子:
从URL静态化与动态化之争谈搜索引擎优化技术(SEO)的学习 程序代码
www.example.com/article/bin/answer.foo?language=en&answer=3&sid=98971298178906&query=URL
language=en – 标明这篇文章的语言
answer=3 – 这篇文章含有数字3
sid=8971298178906 – 会话标识代码是8971298178906
query=URL – 使这篇文章被找到的查询是[URL]

并不是所有的参数都提供额外的信息。所以将这个网址重写为www.example.com/article/bin/answer.foo?language=en&answer=3 可能不会引起任何问题,因为所有不相关的参数都去掉了。

下面是一些经过认为修改而看起来像是静态网址的例子。相比较没有重写、直接提供动态网址来说,这些网址可能会引起更多抓取方面的问题。
从URL静态化与动态化之争谈搜索引擎优化技术(SEO)的学习 程序代码
www.example.com/article/bin/answer.foo/en/3/98971298178906/URL
www.example.com/article/bin/answer.foo/language=en/answer=3/ sid=98971298178906/query=URL
www.example.com/article/bin/answer.foo/language/en/answer/3/sid/ 98971298178906/query/URL
www.example.com/article/bin/answer.foo/en,3,98971298178906,URL


如果您将动态网址重写成如上所述的示例的话,可能会导致我们很多不必要的抓取,因为这些网址中都含有会话标识 (sid) 和查询 (query) 参数的可变值,这无形中生成了很多看起来不同的 URL ,而他们包含的内容却是相同的。这些格式让我们很难理解通过这个网址返回的实际内容和参数URL以及98971298178906是无关的。不过,下面这个重写的例子却将所有无关的参数都去掉了:
从URL静态化与动态化之争谈搜索引擎优化技术(SEO)的学习 程序代码
www.example.com/article/bin/answer.foo/en/3


尽管我们可以正确地处理这个网址,我们还是不鼓励您使用这样的重写。因为它很难维护,而且一旦一个新的参数被加到原始的动态网址,那么这个网址就需要马上更新。不这样做的话就会再次导致生成一个隐藏了参数的貌似静态网址的 URL 。所以最好的解决方法是通常将动态网址保持他们原来的样子。或者,如果您去掉不相关的参数,请记住一定要保持这个网址是动态的:
从URL静态化与动态化之争谈搜索引擎优化技术(SEO)的学习 程序代码
www.example.com/article/bin/answer.foo?language=en&answer=3


到这,GOOGLE的解答完毕,Lonmen还想重复那句话,SEO的学习要向前看,要我自己多思考总结,切记被所谓的法则和公式框住了自己的思维。