当前位置: 首页 > ai >正文

Nginx 搭建支持多版本和前端路由的静态网站

在你的场景下,history/ 目录是上一个版本,main/ 目录是当前版本。你希望通过 Nginx 反向代理,并利用 try_files 机制,使页面刷新时仍能正常访问(避免 404),同时支持 SPA 前端路由,并且能够切换不同版本的资源。


一、Nginx 解决方案

你可以使用 try_files 结合 main/ 和 history/ 目录,实现:

  • 默认加载 main/ 版本
  • 如果 main/ 目录找不到资源,就回退到 history/
  • 支持前端 SPA 刷新

Nginx 配置

nginx
复制编辑
server {listen 80;server_name yourdomain.com;location / {root /var/www/html;index index.html;try_files $uri $uri/ /main/index.html;}# 代理 main 版本location /main/ {root /var/www/html;index index.html;try_files $uri $uri/ /main/index.html;}# 代理 history 版本(如果 main 目录找不到文件,则回退到 history 版本)location /history/ {root /var/www/html;index index.html;try_files $uri $uri/ /history/index.html;}# 处理前端路由刷新 404 问题location /app/ {root /var/www/html;index index.html;try_files $uri /main/index.html;}error_page 404 /main/index.html;
}

二、关键点解析

  1. try_files $uri $uri/ /main/index.html;

    • 先尝试访问请求的静态文件 ($uri),如果找不到,再尝试访问目录 ($uri/),最后回退到 main/index.html 处理 SPA 路由。
  2. 支持 main/ 和 history/ 目录

    • /main/ 目录是当前版本,默认使用它。
    • /history/ 目录是上一个版本,如果 main/ 目录中找不到资源,就会尝试从 history/ 目录加载。
  3. error_page 404 /main/index.html;

    • 避免用户直接刷新时 404,Nginx 会回退到 main/index.html 让前端框架处理路由。

三、前端如何切换版本?

1. 通过 URL 参数控制

你可以在前端代码中检测 URL 参数,如 ?version=history,然后动态切换资源:

javascript
复制编辑
const version = new URLSearchParams(window.location.search).get("version") || "main";
document.write(`<script src="/${version}/app.js"></script>`);

2. Nginx 变量控制

如果你希望动态切换版本,可以使用 Nginx 变量:

nginx
复制编辑
set $version main; # 默认版本
if ($arg_version = history) {set $version history;
}
location / {try_files $uri /$version/index.html;
}

这样,你可以通过 yourdomain.com?version=history 访问历史版本。


三、总结

方案适用场景主要优点主要缺点
try_files 机制适用于 SPA 应用的版本切换切换新旧版本简单,不影响前端代码需要正确配置 Nginx
URL 参数控制前端加载适用于用户可自由选择版本用户体验好,可以灵活回退版本需要前端代码支持
Nginx 变量控制适用于自动化切换版本配置灵活,自动适配不同版本需要 Nginx 解析请求参数

这个方案可以完美解决前端发版导致的页面刷新问题,同时支持新旧版本共存!

http://www.xdnf.cn/news/4443.html

相关文章:

  • 高斯牛顿法 梯度下降法 LM算法的区别
  • 【ARM AMBA AHB 入门 3 -- AHB 总线介绍】
  • Postman中https和http的区别是什么?
  • Linux 下MySql主从数据库的环境搭建
  • 什么是回调 钩子 Hook机制 钩子函数 异步编程
  • 【Prometheus】业务指标与基础指标的标签来源差异及设计解析
  • 4大主流行业CRM需求精解:精准匹配业务痛点与选型策略
  • 数据结构与算法-单链表的应用
  • C语言学习之字符函数和字符串函数
  • 【Python】让Selenium 像Beautifulsoup一样,用解析HTML 结构的方式提取元素!
  • Spark 之 YarnCoarseGrainedExecutorBackend
  • Linux基本操作——网络操作文件下载
  • 1、RocketMQ 核心架构拆解
  • $在R语言中的作用
  • mdadm 报错: buffer overflow detected
  • 数字电子技术基础(五十五)——D触发器
  • 5月13日观测云发布会:这一次,我们不只是发布产品
  • 项目改 pnpm 并使用 Monorepo 发布至 npm 上
  • ChatGPT-4o:临床医学科研与工作的创新引擎
  • SQL 子查询
  • 深入浅出理解常见的分布式ID解决方案
  • 理解网站导航文件:robots.txt、sitemap.xml与LLMs.txt的全面解析
  • 控制mac地址表端口安全
  • 前端面经-VUE3篇(四)--pinia篇-基本使用、store、state、getter、action、插件
  • 【免费】2003-2018年全国各地级市进出口总额数据
  • Nginx 性能调优与深度监测全攻略
  • AI——认知科学中的认知架构建立步骤与方法
  • 【Prometheus】业务指标与基础指标的标签来源差异及设计解析(扩展版)
  • oracle 数据库sql 语句处理过程
  • LeetCode 热题 100_最长回文子串(93_5_中等_C++)(暴力破解法;动态规划)