SPA单页面应用优化SEO

devtools/2025/3/9 22:21:20/

1.SSR服务端渲染

将组件或页面通过服务器生成html,再返回给浏览器,如nuxt.js或vue-server-renderer

javascript">const Vue = require('vue');
const server = require('express')();
const renderer = require('vue-server-renderer').createRenderer();const vueApp = new Vue({data() {return {url: 'http://localhost:8080'}},template: `<div>访问的URL是: {{ url }}</div>`
});server.get('*', (req, res) => {const context = {url: req.url};renderer.renderToString(vueApp, context, (err, html) => {if (err) {res.status(500).end('Internal Server Error');return;}res.end(`<!DOCTYPE html><html lang="en"><head><title>Hello</title></head><body>${html}</body></html>`);});
});server.listen(8080);

2.静态化

目前主流的静态化主要有两种:
(1)通过程序将动态页面抓取并保存为静态页面,这样的页面的实际存在于服务器的硬盘中。


假设我们有一个简单的Node.js应用,它使用Express框架来处理路由,并使用Puppeteer来抓取页面并保存为静态HTML。

javascript">const express = require('express');
const puppeteer = require('puppeteer');
const fs = require('fs');const app = express();app.get('/generate-static', async (req, res) => {const browser = await puppeteer.launch();const page = await browser.newPage();await page.goto('http://localhost:3000/page2', {waitUntil: 'networkidle2'});const content = await page.content();await browser.close();fs.writeFile('static/page2.html', content, (err) => {if (err) {return res.status(500).send('Error saving static file');}res.send('Static file generated successfully');});
});app.get('/page2', (req, res) => {res.send('<html><body><h1>Page 2 Content</h1></body></html>');
});app.use(express.static('static'));app.listen(3000, () => {console.log('Server is running on http://localhost:3000');
});

(2)通过WEB服务器的 URL Rewrite的方式,它的原理是通过URL重写将静态URL映射到动态处理逻辑,最终返回的是静态内容;

首先,假设我们有一个简单的Node.js应用,提供动态内容:

javascript">const express = require('express');
const app = express();app.get('/dynamic-page2', (req, res) => {res.send('<html><body><h1>Dynamic Page 2 Content</h1></body></html>');
});app.listen(3000, () => {console.log('Server is running on http://localhost:3000');
});

配置Nginx以实现URL重写,当用户访问http://example.com/page2时,Nginx会将请求重写为/dynamic-page2,然后代理到运行在localhost:3000的Express应用。尽管URL看起来是静态的,但实际上返回的是动态生成的内容。

server {listen 80;server_name example.com;location /page2 {rewrite ^/page2$ /dynamic-page2 break;proxy_pass http://localhost:3000;}location / {proxy_pass http://localhost:3000;}
}

 3.针对爬虫处理

通过检查请求头中的 User-Agent 来判断请求是否来自爬虫,如果是爬虫请求,则使用 Puppeteer 生成页面;

javascript">const express = require('express');
const puppeteer = require('puppeteer');const app = express();
const PORT = 3000;// 中间件:检查用户代理是否为爬虫
const isCrawler = (req) => {const userAgent = req.headers['user-agent'];return /Googlebot|Bingbot|Baidu|Tencent|Sogou/.test(userAgent);
};// 路由处理
app.get('/', async (req, res) => {if (isCrawler(req)) {// 如果是爬虫请求,则使用 Puppeteer 生成页面const browser = await puppeteer.launch();const page = await browser.newPage();// 访问需要爬取的 URLawait page.goto('https://example.com', { waitUntil: 'networkidle0' });// 获取生成的 HTMLconst content = await page.content();// 关闭浏览器await browser.close();// 返回爬虫请求的 HTMLres.send(content);} else {// 正常用户的请求可以返回一个简单的提示res.send('<h1>欢迎访问我们的网站!</h1>');}
});// 启动服务器
app.listen(PORT, () => {console.log(`Server is running at http://localhost:${PORT}`);
});


http://www.ppmy.cn/devtools/165862.html

相关文章

数据结构--【顺序表与链表】笔记

顺序表 template <class T> class arrList :public List<T> //表示 arrList 类以公有继承的方式继承自 List<T> 类 //公有继承意味着 List<T> 类的公共成员在 arrList 类中仍然是公共成员&#xff0c;受保护成员在 arrList 类中仍然是受保护成员。 { …

【Linux】权限相关知识点

思考 我们平时使用Linux创建文件或目录时的默认权限是多少&#xff1f; [rootlocalhost test]# mkdir dir [rootlocalhost test]# touch file [rootlocalhost test]# ll total 0 drwxr-xr-x 2 root root 6 Mar 8 15:23 dir #755 -rw-r--r-- 1 root root 0 Mar 8 15:23 f…

定时任务和分布式任务框架

文章目录 一 Spring Task1.@Scheduled注解介绍2 基本用法(1)使用@EnableScheduling修饰启动类(2)创建定时任务的类(3)fixedDelay(4)fixedRate(5)cron3 执行多个任务4 设置异步执行5 @Async使用自定义线程池6 缺点二 xxl-job介绍架构图与其他任务调度平台的比较运行调…

【leetcode hot 100 206】反转链表

解法一&#xff1a;&#xff08;头插法&#xff09;在遍历链表时&#xff0c;将当前节点的 next 指针改为指向前一个节点。 /*** Definition for singly-linked list.* public class ListNode {* int val;* ListNode next;* ListNode() {}* ListNode(int val)…

html+js 轮播图

<!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>轮播图示例</title><style>/* 基本样式…

PythonCrowler

requests模块 python中原生的一款基于网络请求的模块,作用是模拟浏览器发送请求 指定url-发送请求-获取响应数据-持久化存储 pro1:爬取搜狗首页的页面数据 basic crowler import requests if __name__ __main__:urlhttps://www.sogou.comresrequests.get(url)page_datare…

游戏元宇宙崛起:AI代理IP驱动虚拟世界“无限可能”​

在科技飞速发展的当下&#xff0c;游戏元宇宙正以一种前所未有的姿态崛起&#xff0c;它犹如一颗璀璨的新星&#xff0c;吸引着无数人的目光。而AI代理IP&#xff0c;正成为驱动这个虚拟世界展现“无限可能”的关键力量。 「快代理&#xff5c;11年专注企业级代理IP云服务 —…

Redis 日常运维与故障处理

Redis 日常运维与故障处理 Redis 作为一个高性能的键值存储系统,被广泛应用于缓存、消息队列、排行榜等场景。为了确保 Redis 的稳定运行和高效性能,日常运维和故障处理至关重要。本文将详细介绍 Redis 的日常运维任务、常见故障及其解决方法,帮助运维人员有效管理和维护 R…