一尘不染

使角度爬网-项目开始

angularjs

使用angularJS开发网站时,在开始使用网站之前,您是否需要担心Web爬网程序,还是可以将其推迟到网站完成。

例如,我读过HTML快照是一个很好的解决方案。如果选择执行此操作,则可以在对网站进行编码后实现它,还是必须基于这种功能来创建网站。


阅读 204

收藏
2020-07-04

共1个答案

一尘不染

我认为在项目开始时考虑该策略并在项目结束时实施该策略是很好的。

我们在我正在工作的公司中遇到了问题。

在所有情况下,您都需要向GET端点回答GET请求,例如

...?_escaped_fragment_=/home

Google或Bing等何时会抓取页面

...#/home

有关详细信息,请参见Google官方文档

问题是您将如何填充资源的内容

...?_escaped_fragment_=:path

有不同的策略:

每次搜寻器要求资源时,使用PhantomJS生成动态快照

这包括在运行时生成PhantomJS进程,将生成的HTML页面的内容重定向到输出,并将其发送回搜寻器。

如果您的网站上有很多动态的可抓取内容,我认为这是最横向,最透明的解决方案。

在构建时或点击网站CMS的保存按钮时,使用PhantomJS生成静态快照

如果您的可抓取内容的内容从不更改或仅不时更改,则这很好。

在开发时或单击网站CMS的保存按钮时,生成静态的“等效”内容文件

这是一个非常便宜的解决方案,因为它不涉及PhantomJS。如果内容很简单,并且您可以轻松地编写它或从数据库生成它,那么这很好。

如果内容的检索很复杂,则很难处理,因为您将需要重复代码(一个客户端呈现Angular视图,而一个服务器端为爬虫生成整个页面“等效”内容)。

我提到了PhantomJS解决方案,但是任何无头的浏览器(或者如果可以负担得起的话,浏览器都不会)可以完成工作。
您甚至可以想象能够在不使用任何浏览器的情况下在服务器端呈现视图,而只需在NodeJS服务器中运行JS。


如果您将使用HTML5样式URL或hash或hashbang
URL,也请考虑一下。一旦搜索引擎将内容编入索引,这可能很难更改。我建议使用hashbang风格,即使它可以看作是“丑陋的”。*

2020-07-04