在nginx上部署vue项目(history模式);css
vue-router 默认是hash模式,使用url的hash来模拟一个完整的url,当url改变的时候,页面不会从新加载。可是若是咱们不想hash这种以#号结尾的路径时候的话,咱们能够使用路由的history的模式。好比以下网址:
使用hash模式的话,那么访问变成 http://localhost:8080/bank/page/count/#/ 这样的访问,若是路由使用 history的话,那么访问的路径变成 以下:
http://localhost:8080/bank/page/count 这样的了;html
在路由的配置就是以下:咱们仍是以 vue-cli项目为例:
在src/router/index.js 代码以下:vue
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上就能够了。java
一: apache服务器上的配置以下:nginx
1. 若是咱们如今是使用apache作web服务器的话,咱们须要开启 .htaccess支持便可:
在文件里加上以下,就一切正常了web
<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/ 这个路径,不然匹配不到了。vue-router
2. vue-cli 项目中须要修改 config/index.js 中的build下的 assetsPublicPath: '/bank/page/', 若是使用相对路径,
chunk文件会报错找不到。vue-cli
3. 在apache的 www/bank/page 目录下新建 .htaccess文件,须要修改RewriteRule 为/bank/page/index.html, 不然刷新页面服务端会直接报404错误。apache
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 上便可