我的编程空间,编程开发者的网络收藏夹
学习永远不晚

AngularJS SEO 简易教程

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

AngularJS SEO 简易教程

1. 搭建Prerender服务

实际上就是搭建了一个Prerender服务器,给它传递参数,它帮你把JS动态页面静态化.

  1. git clone https://github.com/prerender/prerender.git 然后cd Prerender进入目录

  2. npm install 安装模块依赖

  3. node server.js 运行服务(可用nohup node server.js &使其运行于后台)

这里有一个坑,Prerender默认用3000端口,注意你的端口不要被占用了,否则它会给出很奇怪的错误提示.

2. 修改nginx.conf

要达到以下目的:

  1. 普通用户访问,会看到正常页面(交给localhost:4000去处理请求)

  2. 如果是爬虫访问,就交给Prerender服务去处理请求

因此,修改nginx.conf的server段如下:

    server {
        listen       80;
        server_name  www.tomi.in tomi.in;
        location ~* / {
            set $prerender 0;
            if ($http_user_agent ~* "baiduspider|twitterbot|facebookexternalhit|rogerbot|linkedinbot|embedly|quora link preview|showyoubot|outbrain|pinterest|slackbot") {
                set $prerender 1;
            }
            if ($args ~ "_escaped_fragment_") {
                set $prerender 1;
            }
            if ($uri ~ "\.(js|css|xml|less|png|jpg|jpeg|gif|pdf|doc|txt|ico|rss|zip|mp3|rar|exe|wmv|doc|avi|ppt|mpg|mpeg|tif|wav|mov|psd|ai|xls|mp4|m4a|swf|dat|dmg|iso|flv|m4v|torrent)") {
                set $prerender 0;
            }
            if ($prerender = 1) {
                rewrite .* /$scheme://$host$request_uri? break;
                proxy_pass http://localhost:3000;
            }
            if ($prerender = 0) {
                proxy_pass http://localhost:4000;
            }
        }
    }

这里做了两件事:

  • 如果是搜索引擎爬虫(header判断)或者有指定的参数_escaped_fragment_那么就反向代理给内部的Prerender服务(localhost:3000),让它去渲染页面

  • 如果是真实的用户,就走正常渠道(localhost:4000)

3. Demo

嗯,之前给过demo,但现在处于安全性的考虑,大家还是直接在百度搜索site:lsjlt.com好了。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

AngularJS SEO 简易教程

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

AngularJS SEO 简易教程

我们知道 Angular 是 MVC 框架,页面内容是动态加载的,所以如果由搜索引擎的蜘蛛来爬的话,根本爬不出实际的东西,Prerender 应运而生。你可以把它看成是一个能够读懂 javascript 的服务器端浏览器 (Server-side browser),读懂 js 之后,它能够输出由 js 动态加载的页面内容,这给爬虫来看就正合适。业界最简单的方案是使用 Prerender + nginx 反向代理。这里以 tomi.in 为例介绍配置流程。
2022-06-21

Java反射简易教程

关于Java反射,我们需要弄懂以下几个问题:反射是什么?反射有什么用?怎么用反射?下面我们来一一进行讲解:一、反射是什么?Reflection的意思是“反射、映象、倒影”,用在Java身上指的是我们可以于运行时加载、探知、使用编译期间完全未
2023-05-30

简易教程:更改 MacBook 密码

如何通过系统设置更改MacBook密码这是在Mac或MacBook上更改登录密码的最简单,最快的方法;唯一的条件是您必须知道当前密码才能执行此操作。我建议您考虑以下其他方法,如果您忘记了MacBook密码。如果您记得旧密码,请按以下步骤更改
2023-08-02

简单易学的WIN7安装教程

没有U盘和光盘的情况下,最简便方便的方式就是进行在线安装Win7系统。只要确保系统的兼容性,你可以在线安装Win7系统,以便快速体验新系统。下面就来看看如何操作吧。1、先给自己的台式电脑下载小鱼系统重装系统软件。2、选择win7系统,点击“
2023-07-15

简易教程:在Windows上安装PHP5.2.17

在Windows操作系统上安装PHP5.2.17是一个相对简单的过程,下面将为大家提供一个简易教程,包括具体的代码示例和步骤。步骤一:下载PHP5.2.17首先,访问PHP官方网站(https://www.php.net/release
简易教程:在Windows上安装PHP5.2.17
2024-03-04

简易教程:快速安装Python的pip

快速上手:Python安装pip的简易教程,需要具体代码示例Python是一种简单易用、功能强大的编程语言,广泛应用于数据分析、Web开发、人工智能等领域。而pip则是Python的包管理工具,能够方便地安装、升级和管理Python的各种
简易教程:快速安装Python的pip
2024-01-17

Jdk1.8的安装简易教程(Linux和windows)

jdk (SunMicrosystems针对java开发员的产品)JDK是 Java 语言的软件开发工具包,主要用于移动设备、嵌入式设备上的java应用程序。JDK是整个java开发的核心,它包含了JAVA的运行环境(JVM+Javwww.
2022-06-04

ubuntu18.04安装搜狗拼音的简易教程

1.下载好搜狗安装包http://pinyin.sogou.com/linux/ ,注意位数! 2.打开终端安装依赖 sudo apt install libfcitx-qt0 3.提取下载好的搜狗安装包到临时文件夹 unpackc
2022-06-04

Ubuntu20.04防火墙设置简易教程(小白)

前言 在现在这个网络越发便捷的社会,各种网络勒索病毒层出不穷,即使是Google浏览器也是在不断的更新版本修复漏洞。很多人认为只有Windows系统才容易中病毒,若使用linux系统就不容易中病毒,经常让自己的电脑裸奔运行,既不装杀毒软件,
2022-06-04

简明易懂的数据库入门教程

数据库是用于存储和管理数据的系统。它可以帮助我们组织和检索大量数据,并提供数据安全性和一致性保证。下面是一个简明易懂的数据库入门教程:1. 数据库类型目前常见的数据库类型有关系型数据库(如MySQL、Oracle)和非关系型数据库(如Mon
2023-09-13

简单易懂的Dedecms删除栏目教程

Dedecms 是一款常用的开源内容管理系统,但是对于一些新手可能会有些难以理解的功能操作,比如删除栏目。今天我们就来教大家如何简单易懂地删除 Dedecms 中的栏目。首先,需要登录 Dedecms 的后台管理系统,在导航栏中找到“栏目
简单易懂的Dedecms删除栏目教程
2024-03-15

简明易懂的Linux CentOS PHP7安装教程

Linux CentOS系统是一种广泛使用的操作系统,而PHP7又是一种常见的服务器端脚本语言。将它们结合起来,可以实现许多强大的网络应用。本文将向您介绍如何在Linux CentOS系统上安装PHP7,并附有具体的代码示例,让您能够轻松上
简明易懂的Linux CentOS PHP7安装教程
2024-03-07

使用numpy生成随机数的简易教程

教你使用numpy生成随机数numpy是Python的一个数学库,提供了丰富的数值处理函数和工具。其中一项常用功能是生成随机数的能力,这对于模拟实验、数据分析以及机器学习等领域非常有用。本文将向你介绍如何使用numpy生成随机数,并提供
使用numpy生成随机数的简易教程
2024-01-26

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录