Nginx部署history路由模式的vue项⽬

问题 :Nginx通过location配置多个前端项⽬,如果前端使⽤了history路由,多级⽬录状态下刷新⻚⾯,nginx会报404或者500

前端框架使⽤的是: vue-cli

脚⼿架打包编译配置为:

javascript 复制代码
build: {
// Template for index.html
index: path.resolve(__dirname, '../dist/index.html'),
// Paths
assetsRoot: path.resolve(__dirname, '../dist'),
assetsSubDirectory: 'static',
assetsPublicPath: '/vdp',

nginx配置为:

java 复制代码
location /vdp {
alias /usr/local/app/dev/vdp/vdp-web/dist/;
try_files $uri $uri/ /vdp/index.html;
index index.html index.htm;
}

/vdp 是 location 的匹配规则;

alias 指定了 location 匹配到的请求所对应的⽂件路径。

下⾯这个配置才是关键:

官⽹对try_files的解释 https://nginx.org/en/docs/http/ngx_http_core_module.html#try_files

try_files 处理在当前上下⽂中执⾏。⽂件的路径是 file根据 root和alias指令从参数构造的。

可以通过在名称末尾指定斜杠来检查⽬录是否存在,例如 $uri/ 。如果未找到任何⽂件, uri 则会进⾏内部重定向到最后⼀个参数中指定的⽂件。

这⾥的配置是为了⽀持 vue 的 history 路由模式,即在浏览器中输⼊URL时,不会向服务器发送请求,⽽是直接在浏览器中显示对应的⻚⾯。因此,这⾥需要将所有请求都重定向到 /vdp/index.html ,以便 vue-router 能够正确地处理路由,此处的 /vdp/index.html 是当前上下⽂中的路径;

总结:我理解的是当⽤户输⼊ www.xxx.com/vdp/home 的时候,浏览器⾸先请求nginx服务器资源,当匹配到 /vdp/ 的时候,服务器返回了 alias ⾥⾯的资源,并在浏览器端创建了

vdp ⽬录,将请求的资源放置于该⽬录下;当继续匹配到 /vdp/home 的时候,由于浏览器不

会向服务器请求资源,所以最后会加载 try_files 中设置的 vdp ⽬录下的 index.htm

相关推荐
customer081 小时前
【开源免费】基于SpringBoot+Vue.JS个人博客系统(JAVA毕业设计)
java·vue.js·spring boot·后端·开源
乐多_L1 小时前
使用vue3框架vue-next-admin导出表格excel(带图片)
前端·javascript·vue.js
初尘屿风1 小时前
基于微信小程序的电影院订票选座系统的设计与实现,SSM+Vue+毕业论文+开题报告+任务书+指导搭建视频
vue.js·微信小程序·小程序
customer081 小时前
【开源免费】基于SpringBoot+Vue.JS打卡健康评测系统(JAVA毕业设计)
java·vue.js·spring boot·后端·开源
合法的咸鱼2 小时前
uniapp 使用unplugin-auto-import 后, vue文件报红问题
前端·vue.js·uni-app
胡桃不是夹子2 小时前
vue登陆下拉菜单
前端·javascript·vue.js
BeanInJ2 小时前
当一个后端下载了一个VUE开源项目,怎么开始着手玩一下
前端·vue.js·开源
ONEPEICE-ing2 小时前
快速入门Springboot+vue——MybatisPlus多表查询及分页查询
前端·vue.js·spring boot·mybatis
一个处女座的程序猿O(∩_∩)O3 小时前
Django+Vue3全栈开发实战:从零搭建博客系统
vue.js·python·django·sqlite
m0_748238784 小时前
Nginx 负载均衡详解
运维·nginx·负载均衡