nginx部署使用history模式的vue项目详细配置【可多级目录】
介绍
本文是篇详细的介绍vue项目在history模式下发布时build,项目如何配置,nginx如何配置,才能正常的使用历史模式。或者在二级目录下,多级路径下也能正常使用历史模式。
本文的例子中假设,nginx全部都是配置在 flytree.can 域名下。
且路由中配置有以下路径:
const routes = [
{ path: '/', redirect: "/index"},
{ path: '/login', component: Login },
{ path: '/welcome', component: Welcome }
]
一级路径的配置
应用放在服务器根目录下。路由也就是域名后的第一级路径。如:
| url | 对应打开路由 |
|---|---|
| http://www.flytree.can/login | /login |
| http://www.flytree.can/welcom | /welcom |
路由配置
const router = new VueRouter({
mode: 'history',
routes
})
nginx配置
location / {
try_files $uri $uri/ /index.html;
}
二级路径的配置
应用不是放在服务器根目录下,而是location有上下文的。如配置了web上下文,则:
| url | 对应打开路由 |
|---|---|
| http://www.flytree.can/web/login | /login |
| http://www.flytree.can/web/welcom | /welcom |
路由配置
如果在ngnix代理的时候不是配置到根路径/的话,则要配置base,它指定的是应用的基路径。例如,如果整个单页应用服务在 /app/ 下,然后 base 就应该设为 "/app/"。
router/index.js配置:
const vueRouter = new Router({
mode: "history",
base: "/web",
routes: routes
})
配置了base后,应用就会在base之后打开了,如,后面配置了个/login路由,则是在/web/login中打开此路由。
项目config配置
注:由于项目里使用的是老版本的vue-cli,新版本@vue/cli配置会在旁说明。
老版本的配置文件在config/index.js中,如果是cli 3.x后续版本,需在项目 (和 package.json 同级的) 根目录中创建vue.config.js文件进行配置。
const path = require('path');
module.exports = {
module.exports = {
build: {
// 指定生成的 index.html 的输出路径 (相对于 配置文件所在路径)。也可以是一个绝对路径。
// 新版本使用:indexPath
index: path.resolve(__dirname, '../web/index.html'),
// 指定生成的 资源 的输出的目录 (相对于 配置文件所在路径)。此,build后到dist目录下。注意目标目录在构建之前会被清除。
// 新版本使用:outputDir
assetsRoot: path.resolve(__dirname, '../web'),
// 指定除了index.html外的静态资源的目录
// 新版本使用:assetsDir
assetsSubDirectory: 'public',
// 部署应用包时的基本 URL。指定打包后,index.html里面引用资源的的相对地址。
// 这个值也可以被设置为空字符串 ('') 或是相对路径 ('./'),这样所有的资源都会被链接为相对路径
// 如我在index.html中应用了张在pulblic下的图片flytree.jpg
// 则引用是 src='./public/flytree.jpg'
// 新版本:publicPath
assetsPublicPath: '/web/',
}
}
}
配置以后bulid后,部署的文件会在项目下web文件下。
外部文件应用配置
如配置了assetsPublicPath路径,如这里配置的是./相对路径,则在发布的时候要将引用的静态资源设置在,其路径里,如:
<img src="./public/img/flytree.png">
<script>
axios.get('./public/JSON/data.json')
</script>
为了方便开发和发布时使用静态资源,可以:
// main.js中配置
window.base_file_url =
process.env.NODE_ENV === 'production' ? '.' : ''
// 使用
axios.get(base_file_url + '/public/JSON/data.json')
nginx的配置
location /web {
alias F:/Program_D/work/demo/web/;
try_files $uri $uri/ /web/index.html;
}
如此,项目就部署在http://www.flytree.cam/web下了。
多级路径的配置
可能会有人说,谁TM竟然要这么麻烦,搞这么多级路径干啥。但事实就是还真能遇到就要配这么多级的路径。要不然就不会有本文了。
router配置
注:这里base可以配置多级路径,比如:
const vueRouter = new Router({
mode: "history",
base: "/app/web",
routes
})
那么,当前应用将部署在/app/web下:
| url | 对应打开路由 |
|---|---|
| http://www.flytree.can/app/web/login | /login |
| http://www.flytree.can/app/web/welcom | /welcom |
| 若要配置多级路径,其它的配置也要作修改, |
项目config配置
配置后,build后会生成一个有层级的文件夹。
const path = require('path');
module.exports = {
module.exports = {
build: {
// 指定生成的 index.html 的输出路径 (相对于 配置文件所在路径)。也可以是一个绝对路径。
// 新版本使用:indexPath
index: path.resolve(__dirname, '../app/web/index.html'),
// 指定生成的 资源 的输出的目录 (相对于 配置文件所在路径)。此,build后到dist目录下。注意目标目录在构建之前会被清除。
// 新版本使用:outputDir
assetsRoot: path.resolve(__dirname, '../app/web'),
// 指定除了index.html外的静态资源的目录
// 新版本使用:assetsDir
assetsSubDirectory: 'public',
// 部署应用包时的基本 URL。指定打包后,index.html里面引用资源的的相对地址。
// 这个值也可以被设置为空字符串 ('') 或是相对路径 ('./'),这样所有的资源都会被链接为相对路径
// 如我在index.html中应用了张在pulblic下的图片flytree.jpg
// 则引用是 src='./public/flytree.jpg'
// 新版本:publicPath
assetsPublicPath: '/app/web/',
}
}
}
nginx配置
location /app/web/ {
# alias F:/Program_D/work/demo/app/web/;
root F:/Program_D/work/demo/;
try_files $uri $uri/ /app/web/index.html;
}
原理分析
就拿这个多级的举例吧。
| url | 对应打开路由 |
|---|---|
| http://www.flytree.can/app/web/login | /login |
| http://www.flytree.can/app/web/welcom | /welcom |
当访问 http://www.flytree.can/app/web/login 时,
- nginx 配置了上下文
/app/web/。所以$uri的值是/login。 - try_files 会将此路径,响应为
root+/app/web/index.html。 - 浏览器打开了
index.html也就是history模式的vue项目,此时vue-router匹配路由/login,将此路由内容插入到index.html中。
补充说明
nginx配置的一些说明
- 关于 try_files
try_files $uri $uri/ /index.html;
这个命令可以将其后的参数,响应到最后一个参数的路径中去。在这里通俗来说,就是匹配到啥$uri我都给你响应index.html。前提是有index.html,否则会响应到别的location配置中去(有的话),或404。
- root 和 alias 的区别
首先这两玩意都是指定服务器的响应文件路径的。
- 使用
root配置时,则配置到 项目路径的上层路径。此时,nginx会去读取的文件路径是,root + location的上下文(其后面跟着的)拼成的路径。 alias就配置到项目的完整的路径,配置到index这一级。nginx会去读取的文件路径时就会按照alias指定的路径读取。
参考内容
- 关于
try_files $uri $uri/ /index.html的说明:
Niginx中Vue Router 历史(history)模式的配置 - vue-router history模式在nginx二级目录下的配置
nginx部署使用history模式的vue项目详细配置【可多级目录】的更多相关文章
- Jenkins+SpringCloud(多模块)+Vue项目详细配置
一.Jenkins安装及所需插件安装 安装过程略. 我这用到工具包括JDK.Git.Maven.NodeJS:可以选择自行在服务器安装,也可以通过Jenkins自动安装,位置在系统管理 >全局工 ...
- [转]Vue项目全局配置微信分享思路详解
这篇文章给大家介绍了vue项目全局配置微信分享思路讲解,使用vue作为框架,使用vux作为ui组件库,具体内容详情大家跟随脚本之家小编一起学习吧 这个项目为移动端项目,主要用于接入公众号服务.项目采用 ...
- 如何为你的 Vue 项目添加配置 Stylelint
如何为你的 Vue 项目添加配置 Stylelint 现在已经是 9102 年了,网上许多教程和分享帖都已经过期,照着他们的步骤来会踩一些坑,如 stylelint-processor-html 已经 ...
- linux vue uwsgi nginx 部署路飞学城 安装 vue
vue+uwsgi+nginx部署路飞学城 有一天,老男孩的苑日天给我发来了两个神秘代码,听说是和mjj的结晶 超哥将这两个代码,放到了一个网站上,大家可以自行下载 路飞学城django代码#这个代码 ...
- `vue-router`的`History`模式下的项目发布
背景 脚手架版本号:vue cli 3.x 项目路由:vue-router的History模式 原理:url路由处理逻辑从后端转移到前端. 参考:https://developer.mozilla.o ...
- 利用vue-cli3快速搭建vue项目详细过程
一.介绍 Vue CLI 是一个基于 Vue.js 进行快速开发的完整系统.有三个组件: CLI:@vue/cli 全局安装的 npm 包,提供了终端里的vue命令(如:vue create .vue ...
- vue-cli安装以及搭建vue项目详细步骤
vue init webpack projectname(projectname是你项目的名称) 创建项目卡住不动解决方案: https://cli.vuejs.org/zh/guide/instal ...
- vue项目如何配置路由
vue3项目中如何配置路由 1.下载vue-router,在路由文件中引入相关依赖 import {createRouter,createWebHashHistory} from 'vue-route ...
- vue项目搭建及创建、目录结构、项目启动、全局配置
Vue项目环境搭建 """ node ~~ python:node是用c++编写用来运行js代码的 npm(cnpm) ~~ pip:npm是一个终端应用商城,可以换国内 ...
- vue项目中配置scss
之前创建 vue 项目的时候没有选择 scss 预编译,现在项目中要使用,不知道如何配置,网上搜了下全都是: npm install sass-loader --save-devnpm instal ...
随机推荐
- java基础的项目
334,零钱通 思路: (1) 先完成显示菜单,并可以选择菜单,给出对应提示 (2) 完成零钱通明细,简单的话可以使用String拼接 (3)完成收益入账 完成功能驱动程序员增加新的变化和代码 ( ...
- 【教程】深入探究 JS代码混淆与加密技术
引言 在网络世界中,保护代码安全是至关重要的一环.JS代码混淆与加密技术则成为了开发者们常用的手段之一.本文将深入探讨混淆和加密的概念,以及其实现原理和应用方法,帮助读者更好地了解并运用这些技术. 概 ...
- 用于vivado的TCL脚本创建工程
用于实现在脚本所在的目录创建工程并初始化工程 点击查看代码 #获取脚本所在的文件 variable My_File [file normalize [info script]] #prj_path_f ...
- Zotero 插件:DOI Manager 使用
一.项目信息与下载安装 https://github.com/bwiernik/zotero-shortdoi 根据readme,下载并安装即可.可能访问会失败,多试几次,总是能够成功的. 本博客编写 ...
- 【福利活动】深度体验OpenHarmony对接华为云IoT
本文主要介绍基于OpenHarmony 3.0来接入IoTDA,以BearPi-HM_Nano开发板为例,使用huaweicloud_iot_link SDK对接华为云物联网平台的简单流程.文末为 ...
- 李东山:如何让 OpenHarmony 支持低功耗蓝牙芯片 GR551x
编者按:在 OpenHarmony 生态发展过程中,涌现了大批优秀的代码贡献者,本专题旨在表彰贡献.分享经验,文中内容来自嘉宾访谈,不代表 OpenHarmony 工作委员会观点. 李东山 深圳市汇顶 ...
- keycloak~网站对接到Keycloak的步骤
新网站对接到KC的部署 kc的环境 向kc申请自己的客户端 kc的登录接口 通过code换token接口 刷新token接口 kc的用户信息接口 kc的jwt token说明 1. kc的环境 测试环 ...
- Redis 02 基础命令
数据库 Redis 默认有 16 个数据库. 默认使用的是第 0 个数据库. 不同数据库存不同的值. 切换数据库 select 127.0.0.1:6379> select 1 OK 127.0 ...
- Taurus.MVC 性能压力测试(ap 压测 和 linux 下wrk 压测):.NET Core 版本
前言: 最近的 Taurus.MVC 版本,对性能这一块有了不少优化,因此准备进行一下压测,来测试并记录一下 Taurus.MVC 框架的性能,以便后续持续优化改进. 今天先压测 .NET Core ...
- MogDB/openGauss中merge的语法解析
MogDB/openGauss 中 merge 的语法解析 近期了解学习了 MogDB/openGauss 中 merge 的使用,merge 语法是根据源表对目标表进行匹配查询,匹配成功时更新,不成 ...