使用nginx方向代理部署Vue项目刷新页面404的问题解决

这篇具有很好参考价值的文章主要介绍了使用nginx方向代理部署Vue项目刷新页面404的问题解决。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

问题假设

  • 部署出现的问题为:由于项目中使用的vue router 项目直接使用node环境部署项目,在同一个路由如: 192.168.1.30:/home刷新浏览器正常 nginx部署刷新不出现404 /nginx not found 如何解决?
  • 以下是我的想法:似乎是nginx代理使其直接访问文件,而没有使项目的路由生效从而正确加载资源

原理探究

这种Nginx配置背后的原理涉及到前端路由和服务器的工作方式。文章来源地址https://www.toymoban.com/news/detail-722423.html

  1. 前端路由:
    • 在前端开发中,SPA(Single Page Application)应用程序使用前端路由来实现页面切换和导航。
    • 前端路由是在浏览器中处理的,而不是通过传统的页面请求和刷新。
    • SPA应用通常使用JavaScript库或框架(如Vue Router、React Router等)来管理前端路由。
    • 这些路由库允许应用程序的不同路径映射到不同的组件或页面。
  2. 服务器处理:
    • 当浏览器发出请求时,Web服务器(如Nginx)会根据请求的路径来定位并返回相应的资源或页面。
    • 在传统的Web应用中,服务器会查找匹配的HTML文件并将其发送给浏览器。然而,在SPA中,服务器通常只返回应用的入口点(例如,index.html),而所有的路由和页面切换是在浏览器中通过前端路由进行管理的。
  3. 问题的根本:
    • 当使用前端路由时,如果你直接访问特定路径,例如 http://example.com/home,浏览器中的前端路由会正确解析这个路径并显示对应的页面,因为JavaScript路由库知道如何处理它。然而,如果你刷新页面,或者直接在地址栏中输入URL,服务器会尝试查找与该路径匹配的实际文件,但在SPA中,通常没有与每个路由路径相对应的独立HTML文件,因此服务器会返回404错误。
  4. 解决方案:
    • 为了解决这个问题,需要配置Nginx,以便对所有请求都返回应用的入口点(通常是 index.html)。这样,不管浏览器中的路径是什么,服务器都会返回相同的index.html。一旦浏览器加载了这个HTML文件,前端路由库会根据URL来呈现正确的页面内容。
  • 所以,Nginx配置的关键点是将所有请求都传递给Vue应用的 index.html,这个HTML文件包含了前端路由的逻辑,它会根据URL来呈现不同的内容,从而确保前端路由能够正确处理所有的路由请求,无论是直接访问还是刷新页面。
  • 它解决了前端路由在SPA中的刷新问题,让SPA应用可以在不同的路由之间无缝导航。

问题解决

  • 当使用Vue Router时,前端路由是在客户端进行处理的,而Nginx作为反向代理服务器默认只处理静态文件的请求。这就是为什么直接访问 xxx.xxx.xxx.xxx:/home 时正常工作,但刷新页面时会出现404错误的原因。
  • 使用通配符来配置Nginx,以使其将所有路由请求都指向Vue应用的 index.html,确保所有的路由请求都交给Vue Router处理。
server {
    listen       80;
    server_name  demo;
    
    location / {
        root   /usr/carehome_vue;
        index  index.html index.htm;
        # 配置让Vue Router处理路由
        try_files $uri $uri/ /index.html; 
    }
}

到了这里,关于使用nginx方向代理部署Vue项目刷新页面404的问题解决的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 服务器部署—若依【vue】如何部署到nginx里面?nginx刷新页面404怎么办?【完美解决建议收藏】

    服务器部署项目我们大家都会遇到,但是有些铁子会遇到很多的问题,比如前端部署nginx如何操作? 前端有单纯的静态页面、还有前后端分离的项目;这里博主直接分享最牛最到位的前后端分离项目的前端部署到nginx上面,以若依项目【springboot+vue】为例,实现将前端部署到

    2024年02月03日
    浏览(59)
  • Vue/React 项目部署到服务器后,刷新页面出现404报错

    问题描述:在本地启动项目一切正常, 部署到服务器上线后出现BUG,项目刷新页面出现404 。 起初以为是自己路由守卫或是token丢失问题,找了一圈终于解决了 产生原因: 我们打开vue/react打包后生成的dist文件夹,可以看到只有一个 index.html 文件及一些静态资源,这个是因为

    2024年02月07日
    浏览(46)
  • 解决Vue3+Vite3 打包部署到nginx后配置非根目录刷新页面报错空白

    报错内容 解决方法 router文件 vite.config.ts nginx.conf 配置中路径apps是我自建的存放前端页面的文件夹 起关键作用的是 try_files $uri $uri/ /demo/index.html ,当然上面项目文件夹demo也需保持一致 alias 后面的路径是Vue项目打包后dist静态文件服务器存放路径,一般在nginx下面建一个文件夹

    2024年02月11日
    浏览(59)
  • vue3项目部署到服务器,刚打开没事,一刷新页面就404

    vue3项目部署到服务器,刚打开没事,一刷新页面就404 不知道什么原因。百度了下才发现问题所在 问题所在: vue-router历史模式的问题: vue3中历史模式,默认改为了HTML5模式: createWebHistory() 解决办法: createWebHistory 换成 createWebHashHistory ,将历史模式,由当前的HTML5模式,改

    2024年01月18日
    浏览(55)
  • 前后端分离用nginx做代理服务器,刷新页面报404 解决方法

    情况一 在nginx配置文件中加上一句话,作用就是nginx代理时候找不到页面会尝试访问这个指定页面,而前端vue项目的话,页面正好是有vue自己进行管理,所以就不会报错了 location /{                 alias /var/www/html/;                 index index.html abc.html;                 tr

    2024年02月09日
    浏览(53)
  • 前端部署nginx刷新后404,解决Nginx刷新页面后404的问题

    使用Nginx部署后,登录页面刷新一下就出来404,如下图: 刷新以后 ,页面变成404 Not Found 查看了一下nginx配置,出现问题的配置是这样的: 修改后的配置是这样的 添加了 try_files $uri $uri/ /index.html, 然后重启一下nginx问题就解决了。 解释: try_files 表示检查文件是否存在,返回

    2024年02月13日
    浏览(51)
  • vue3.2项目中使用history路由模式刷新后页面404

    开发过程中,路由可以正常访问,打包后也可以正常访问,但是一刷新页面就会出现404错误 方法一:修改为Hash路由模式 在router/index.ts文件中,将history路由模式修改为hash路由模式即可。 history路由模式: hash路由模式: 方法二、修改后台伪静态 Nginx: Apache: 可以参考下这篇文

    2024年02月11日
    浏览(53)
  • Linux/openEuler系统部署spring boot+vue前后端分离项目(nginx均衡代理)

    可以看我前面的文章 华为openEuler系统安装openjdk并配置环境变量 openEuler系统安装nginx HUAWEI-OpenEuler系统安装MySQL服务器并使用详细步骤 Ubuntu安装MySQL服务器详细步骤 在确定项目可以正常运行的前提下,进行package打出jar包 npm run build 打包成功后在项目文件路径下出现dist文件夹

    2024年03月24日
    浏览(94)
  • 用Nginx将前端Vue项目部署到云服务器(含代理实现请求跨域)

    记录使用Nginx将 纯前端 的Vue3项目部署到阿里云服务器(Ubuntu 22.04)上,包含通过Nginx代理实现 跨域请求 、以及个人踩坑记录~ 执行下列命令安装: 安装完成后查看nignx版本,显示版本信息则说明安装成果 启动nginx,如正确启动,则不会出现任何提示信息。 nginx启动成功后打

    2024年04月12日
    浏览(45)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包