nginx刷新显示404

前言

nginx部署完项目后,访问时 刷新后 就会出现404的报错界面(没有配置情况下,而且不是首页根目录刷新)

当重新访问首页后,又恢复正常,只要一刷新就会出现这个问题。这是为什么呢?

其实很简单就是你的nginx配置上没有添加重定向跳转。

报错原因

因为web单页面开发模式,只有一个index.html入口,其他路径是前端路由去跳转的,nginx没有对应这个路径,当然就是404了。

解决的方式很简单,就是在我们的代理映射处,配置下面这段代码即可成功搞定,不再出现404!

配置完后 重启nginx服务即可正常的刷新访问了

#在配置中加上try_files,意思跟翻译差不多,“尝试读取文件”。

try_files $uri $uri/ /index.html =404;

 

try_files 表示的是检查文件是否存在,就是指的在每次匹配URL路径的时候,找不到对应的静态资源的时候自动跳转到index.html文件。

还有另外一种404的错误,那就是nginx访问的文件权限问题。

比如,你访问的路径,他要的权限是root权限,而我们启动nginx的权限是普通用户权限,则会因为权限不错,导致无法正常访问。
 

说明

为什么刷新页面会出现这种情况

如:http://192.168.0.180:8080/index.html ,此时刷新页面的时候回去根据浏览器的url, 访问nginx上请求对应的静态资源,而nginx会根据localhost / 的匹配规则在dist文件夹里面没有找到对应的静态文件index,所以就会报错404。

大致就是这样的情况,如有问题欢迎留言交流。

  • 5
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值