在nginx上部署vue项目(history模式)的方法


Posted in Javascript onDecember 28, 2017

vue-router 默认是hash模式,使用url的hash来模拟一个完整的url,当url改变的时候,页面不会重新加载。但是如果我们不想hash这种以#号结尾的路径时候的话,我们可以使用路由的history的模式。比如如下网址:

使用hash模式的话,那么访问变成 http://localhost:8080/bank/page/count/#/ 这样的访问,如果路由使用 history的话,那么访问的路径变成 如下:

http://localhost:8080/bank/page/count 这样的了;

在路由的配置就是如下:我们还是以 vue-cli项目为例:

在src/router/index.js 代码如下:

import Vue from 'vue';
import Router from 'vue-router';
// import HelloWorld from '@/views/HelloWorld';

Vue.use(Router);

const router = new Router({
 mode: 'history', // 访问路径不带井号 需要使用 history模式
 base: '/bank/page', // 基础路径
 routes: [
  {
   path: '/count',
   name: 'count',
   component: resolve => require(['@/views/count'], resolve) // 使用懒加载
  }
 ]
});

不过history的这种模式需要后台配置支持。比如:

当我们进行项目的主页的时候,一切正常,可以访问,但是当我们刷新页面或者直接访问路径的时候就会返回404,那是因为在history模式下,只是动态的通过js操作window.history来改变浏览器地址栏里的路径,并没有发起http请求,但是当我直接在浏览器里输入这个地址的时候,就一定要对服务器发起http请求,但是这个目标在服务器上又不存在,所以会返回404,怎么解决呢?我们现在可以把所有请求都转发到 http://localhost:8080/bank/page/index.html上就可以了。

一: apache服务器上的配置如下:

1. 如果我们现在是使用apache做web服务器的话,我们需要开启 .htaccess支持即可:

在文件里加上如下,就一切正常了

<IfModule mod_rewrite.c>
 RewriteEngine On
 RewriteBase /
 RewriteRule ^index\.html$ - [L]
 RewriteCond %{REQUEST_FILENAME} !-f
 RewriteCond %{REQUEST_FILENAME} !-d
 RewriteRule . /bank/page/index.html [L]
</IfModule>

上面的apache的作用是:把所有服务器上不存在的请求全部转发到 index.html上去,这样就可以直接通过各种url来访问了。

注意:

1. RewriteRule . /bank/page/index.html [L] 这段代码;前面需要加 /bank/page/这样的,因为我在路由配置base里面

加了 /bank/page/ 这个路径,否则匹配不到了。

2. vue-cli 项目中需要修改 config/index.js 中的build下的 assetsPublicPath: '/bank/page/', 如果使用相对路径,

chunk文件会报错找不到。

3. 在apache的 www/bank/page 目录下新建 .htaccess文件,需要修改RewriteRule 为/bank/page/index.html, 否则刷新页面服务端会直接报404错误。

4. 修改httpd.conf文件,开启rewrite_module功能。

5. LoadModule rewrite_module libexec/apache2/mod_rewrite.so,去掉前面的#

6. 然后找到AllowOverride None的那行,把它改成AllowOverride All,来使.htaccess文件生效。

二:nginx服务器上的配置如下:

vue-cli 执行打包命令:

npm run build

如上进行打包,生成dist文件夹,把该文件夹下的文件直接复制到nginx服务器目录下,就可打开项目,但是只有首页可以看到的,刷新一下页面也是404了,原因和上面一样,因此需要在nginx服务器配置对所有的路径或者文件夹进行跳转,重定向到首页 index.html即可:这样就能找到路由了。

nginx服务器配置如下:

1. 首先登录服务器。

2. 进入目录 /etc/usr/local/nginx/conf/下;

执行命令:

2-1 cd /etc/ 回车

2-2 cd /usr/ 回车

2-3 cd loacl/ 回车

2-4 cd nginx 回车

2-5 cd conf 回车

2-6 vi nginx_v4.conf 进入 nginx文件内 新建一个项目的相关配置如下:

比如我们现在的域名地址这样访问的:http://aa.xx.com/bank/page/count , 需要如下配置:

server {
  listen 443;   # 监听本机所有ip上的 443 端口
  listen 80;   # 监听本机所有ip上的 80 端口
  server_name aa.xx.com; # 域名地址
  access_log /data/www/logs/nginx/aa/access.log main; # 新建日志文件
  include nginx_xx.conf; 
  /* 下面是多个location 用于配置路由地址 */
  location / {
   proxy_pass http://aa/;
   include nginx_proxy.conf;
  }
  location /bank/page/ {
   try_files $uri $uri/ /bank;
  },
  /* http://aa.xx.com/bank2/page/count 有多个不同的地址 就加一个如下这个配置 */
  location /bank2/page/ {
   try_files $uri $uri/ /bank2;
  }
  error_page 500 502 503 504 /502.html;
  location = /50x.html {
   root  html;
  }
 }

try_files 指令:

语法:try_files file ... uri 或 try_files file ... = code

默认值:无

作用域:server location

其作用是按顺序检查文件是否存在,返回第一个找到的文件或文件夹(结尾加斜线表示为文件夹),如果所有的文件或文件夹都找不到,会进行一个内部重定向到最后一个参数。

需要注意的是,只有最后一个参数可以引起一个内部重定向,之前的参数只设置内部URI的指向。最后一个参数是回退URI且必须存在,否则会出现内部500错误。命名的location也可以使用在最后一个参数中。与rewrite指令不同,如果回退URI不是命名的location那么

args不会自动保留,如果你想保留args,则必须明确声明。

location指令

语法:location [=|~|~*|^~|@] /uri/ { … }

默认值:无

作用域:server

location指令是用来为匹配的URI进行配置,URI即语法中的"/uri/",可以是字符串或正则表达式。但如果要使用正则表达式,则必须指定前缀。 [@] 即是命名location,一般只用于内部重定向请求。

3. 设置成功后需要重启:nginx重启命令;在 /etc/usr/local/nginx/conf/ 目录下, cd ../ 然后进入sbin目录下 cd sbin 接着运行命令 ./nginx -s reload 重启后即可生效。

4. 在/data/www/logs/nginx/aa/目录下 新建 access.log 文件。

然后nginx保存和退出命令 :wq

直接退出的命令是 :q

5. mac系统下 自带 apache2服务器,需要对apache2作反向代理;配置如下:

进入本地mac apache2配置;

命令:cd /etc/apache2

命令:sudo vi httpd.conf

<VirtualHost *:80>
 ServerName aa.xx.com
 ProxyRequests off
 Header set Access-Control-Allow-Origin *
 <Proxy *>
   Order deny,allow
   Allow from all
 </Proxy>
 <Location /aa>
   ProxyPass http://localhost:8896/
   ProxyPassReverse http://localhost:8896/
 </Location>
 // .... 更多配置省略
</VirtualHost>

然后进入 sbin目录下 启动服务 sudo apachectl start

重启命令如下 sudo apachectl restart

6. java服务端的配置如下 (如果是vm放到开发那边的话,开发那边需要如下处理下,如果页面vm不放在开发那边的话,下面的配置可以忽略)

在项目目录下 webapp/web-inf/view/ 新建文件夹 aa 和 include文件

aa文件下 新建index.vm

如下代码:

#parse("include/common.vm")
#@frame("xx管理",true)
#css(["${version}/business/aa/aa.css"]) // 打包后的css路径,具体看自己的路径
<div id="app"></div>
#js(["${version}/business/aa/aa.js"]) // 打包后的js路径,具体看自己的路径
#end

6-2 java开发需要配置一下:

1 设置路由: /aa 设置路由到 /aa/index.vm

2 这个include/common.vm有一个地址配置,是在disconf上配置的,你加一个

地址配置到 //aa.xx.com/aa/dist 上即可

总结

以上所述是小编给大家介绍的在nginx上部署vue项目(history模式)的方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
Javascript----文件操作
Jan 18 Javascript
Jquery的Tabs内容轮换效果实现代码,几行搞定
Feb 12 Javascript
原生js获取宽高与jquery获取宽高的方法关系对比
Apr 04 Javascript
IE中的File域无法清空使用jQuery重设File域
Apr 24 Javascript
jquery计算鼠标和指定元素之间距离的方法
Jun 26 Javascript
js实现内容显示并使用json传输数据
Mar 16 Javascript
javascript 删除数组元素和清空数组的简单方法
Feb 24 Javascript
详解JS数值Number类型
Feb 07 Javascript
详解关于element el-button使用$attrs的一个注意要点
Nov 09 Javascript
VUE简单的定时器实时刷新的实现方法
Jan 20 Javascript
小程序getLocation需要在app.json中声明permission字段
Apr 04 Javascript
vue自定义指令实现仅支持输入数字和浮点型的示例
Oct 30 Javascript
js实现把时间戳转换为yyyy-MM-dd hh:mm 格式(es6语法)
Dec 28 #Javascript
vue获取dom元素注意事项
Dec 28 #Javascript
vue实现文章内容过长点击阅读全文功能的实例
Dec 28 #Javascript
webpack搭建vue 项目的步骤
Dec 27 #Javascript
JS实现留言板功能[楼层效果展示]
Dec 27 #Javascript
js判断节假日实例代码
Dec 27 #Javascript
Vue的实例、生命周期与Vue脚手架(vue-cli)实例详解
Dec 27 #Javascript
You might like
受疫情影响 动画《Re从零开始的异世界生活》第二季延期至7月
2020/03/10 日漫
SONY ICF-SW55的电路分析
2021/03/02 无线电
php5.3不能连接mssql数据库的解决方法
2014/12/27 PHP
thinkPHP中多维数组的遍历方法
2016/01/09 PHP
Laravel中encrypt和decrypt的实现方法
2017/09/24 PHP
javascript 验证日期的函数
2010/03/18 Javascript
JS获取页面窗口大小的代码解读
2011/12/01 Javascript
JavaScript中的undefined学习总结
2013/11/30 Javascript
jquery通过select列表选择框对表格数据进行过滤示例
2014/05/07 Javascript
基于NodeJS的前后端分离的思考与实践(三)轻量级的接口配置建模框架
2014/09/26 NodeJs
codeMirror插件使用讲解
2017/01/16 Javascript
微信小程序 出现错误:{&quot;baseresponse&quot;:{&quot;errcode&quot;:-80002,&quot;errmsg&quot;:&quot;&quot;}}解决办法
2017/02/23 Javascript
完美解决UI-Grid表格元素中多个空格显示为一个空格的问题
2017/04/25 Javascript
vue-cli创建的项目,配置多页面的实现方法
2018/03/15 Javascript
微信小程序如何像vue一样在动态绑定类名
2018/04/17 Javascript
JSON数据中存在单个转义字符“\”的处理方法
2018/07/11 Javascript
详解如何在Vue里建立长按指令
2018/08/20 Javascript
Vue项目报错:Uncaught SyntaxError: Unexpected token
2018/11/10 Javascript
JavaScript的Proxy可以做哪些有意思的事儿
2019/06/15 Javascript
JavaScript对象属性操作实例解析
2020/02/04 Javascript
javascript 代码是如何被压缩的示例代码
2020/05/06 Javascript
vue 弹出遮罩层样式实例
2020/07/22 Javascript
Python数组遍历的简单实现方法小结
2016/04/27 Python
Python使用sftp实现上传和下载功能(实例代码)
2017/03/14 Python
详解python3中socket套接字的编码问题解决
2017/07/01 Python
Python实现在线暴力破解邮箱账号密码功能示例【测试可用】
2017/09/06 Python
python获取中文字符串长度的方法
2018/11/14 Python
python集成开发环境配置(pycharm)
2020/02/14 Python
matlab灰度图像调整及imadjust函数的用法详解
2020/02/27 Python
Python使用Excel将数据写入多个sheet
2020/05/16 Python
Python如何获取文件路径/目录
2020/09/22 Python
法国珠宝店:CLEOR
2017/01/29 全球购物
马来西亚最热门的在线时尚商店:FashionValet
2018/11/11 全球购物
讲座开场白台词和结束语
2015/05/29 职场文书
nginx的zabbix 5.0安装部署的方法步骤
2021/07/16 Servers
MySql分区类型及创建分区的方法
2022/04/13 MySQL