SPA单页面应用优化SEO

embedded/2025/3/10 18:33:04/

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/embedded/171546.html

相关文章

基于Asp.net的驾校管理系统

作者&#xff1a;计算机学姐 开发技术&#xff1a;SpringBoot、SSM、Vue、MySQL、JSP、ElementUI、Python、小程序等&#xff0c;“文末源码”。 专栏推荐&#xff1a;前后端分离项目源码、SpringBoot项目源码、Vue项目源码、SSM项目源码、微信小程序源码 精品专栏&#xff1a;…

使用express创建服务器保存数据到mysql

创建数据库和表结构 CREATE DATABASE collect;USE collect;CREATE TABLE info (id int(11) NOT NULL AUTO_INCREMENT,create_date bigint(20) DEFAULT NULL COMMENT 时间,type varchar(20) DEFAULT NULL COMMENT 数据分类,text_value text COMMENT 内容,PRIMARY KEY (id) ) EN…

基于Spring Boot的宠物健康顾问系统的设计与实现(LW+源码+讲解)

专注于大学生项目实战开发,讲解,毕业答疑辅导&#xff0c;欢迎高校老师/同行前辈交流合作✌。 技术范围&#xff1a;SpringBoot、Vue、SSM、HLMT、小程序、Jsp、PHP、Nodejs、Python、爬虫、数据可视化、安卓app、大数据、物联网、机器学习等设计与开发。 主要内容&#xff1a;…

达梦数据库查看字符集编码

select SF_GET_UNICODE_FLAG(); 返回 0 代表数据库字符集编码为 GB18030 1 代表数据库字符集编码为 UTF-8 2 代表数据库字符集编码为韩文字符集 EUC-KR

【第20节】C++设计模式(行为模式)-Visitor(访问者)模式

一、问题引出 在面向对象系统的开发和设计过程中&#xff0c;经常会遇到需求变更&#xff08;Requirement Changing&#xff09;的情况。通常&#xff0c;我们已经完成了一个设计并实现了系统原型&#xff0c;但客户又提出了新的需求。为了满足这些新需求&#xff0c;我们不得不…

安装微软最新原版系统,配置好系统驱动并保留OOBE全新体验

记录一种安装原版系统&#xff0c;并在用户使用前安装好所有驱动&#xff0c;以及配置好网络和工作环境&#xff0c;但不影响用户全新体验的方法。 前言 有的时候我们可能会遇到这样一种情况&#xff1a; 需要给别人安装一个微软官网正版的全新系统&#xff0c;用户开机要有OO…

Mac本地安装运行FastDFS

没错&#xff0c;因为毕设...... 服务器过期了&#xff0c;只能装在本地了...... 1.配置 macOS 上需要安装以下依赖&#xff1a; Homebrew&#xff08;macOS 包管理器&#xff09; gcc&#xff08;编译器&#xff09; libevent&#xff08;FastDFS 依赖&#xff09; 安装…

前端开发怎么处理数据的安全

1. 数据加密 传输加密&#xff1a;使用HTTPS协议加密数据传输&#xff0c;防止中间人攻击。 存储加密&#xff1a;对本地存储&#xff08;如LocalStorage、SessionStorage&#xff09;中的敏感数据进行加密&#xff0c;避免明文存储。 加密算法&#xff1a;使用强加密算法&am…