(已解决)宝塔部署Vue项目时非首页刷新404

问题描述:

部署成功后项目正常运行,但是一但非首页刷新就会报错:404

问题解决:

在网页的设置中的配置文件添加上图代码:重启后即可正常运行。

复制代码
## 添加上这个配置
 
location / {
  try_files $uri $uri/ @router;
  index index.html;
}
 
location @router {
  rewrite ^.*$ /index.html last;
}
原理剖析:

Vue路由模式

Vue Router有两种模式来处理页面跳转:

  1. Hash模式 :URL后面带有一个#符号,比如http://example.com/#/about。这种方式浏览器可以直接识别,不需要服务器做特殊处理。
  2. History模式 :URL看起来更"干净",没有#符号,比如http://example.com/about。这种方式需要服务器的帮助来处理这些URL。

为什么刷新会出现404?

当你使用History模式部署Vue应用时,如果直接刷新页面或者通过链接进入非首页,服务器会尝试查找实际的文件或目录。但在SPA(单页应用)中,所有的页面实际上是动态生成的,服务器上并没有对应的具体文件或目录。因此,服务器找不到对应的文件,就会返回404错误。

如何解决404?

要解决这个问题,我们需要告诉服务器:"如果找不到具体的文件或目录,请直接返回index.html。"这是因为SPA中的所有页面都是基于index.html动态生成的。

Nginx配置的作用

我们添加的那段Nginx配置就是用来实现这一点的:

  • try_files $uri $uri/ @router;:尝试找到请求的文件或目录,如果没有找到,就交给@router处理。
  • rewrite ^.*$ /index.html last;:将所有找不到的请求重定向到index.html

这样一来,无论用户刷新页面还是直接通过链接进入其他页面,服务器都会返回index.html,然后前端的Vue Router就能正常工作了。

相关推荐
凯子坚持 c3 分钟前
生产级 Rust Web 应用架构:使用 Axum 实现模块化设计与健壮的错误处理
前端·架构·rust
IT_陈寒9 分钟前
Python 3.12新特性实战:5个让你的代码效率翻倍的隐藏技巧!
前端·人工智能·后端
程序员小寒16 分钟前
前端高频面试题之Vuex篇
前端·javascript·面试
网硕互联的小客服27 分钟前
如何解决 Linux 文件系统挂载失败的问题?
linux·服务器·前端·网络·chrome
程序员爱钓鱼2 小时前
Python 编程实战 · 实用工具与库 — Flask 路由与模板
前端·后端·python
JIngJaneIL2 小时前
旅游|内蒙古景点旅游|基于Springboot+Vue的内蒙古景点旅游管理系统设计与实现(源码+数据库+文档)
java·vue.js·spring boot·论文·旅游·毕设·内蒙古景点旅游
麦麦大数据4 小时前
D038 vue+django西游记问答知识图谱可视化系统
vue.js·django·问答系统·知识图谱·neo4j·可视化·可是还
合作小小程序员小小店5 小时前
web开发,在线%超市销售%管理系统,基于idea,html,jsp,java,ssh,sql server数据库。
java·前端·sqlserver·ssh·intellij-idea
不爱学英文的码字机器5 小时前
重塑 Web 性能:用 Rust 与 WASM 构建“零开销”图像处理器
前端·rust·wasm
浩星6 小时前
react的框架UmiJs(五米)
前端·javascript·react.js