在nginx上部署vue项目(history模式)的方法
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代码如下:
importVuefrom'vue'; importRouterfrom'vue-router'; //importHelloWorldfrom'@/views/HelloWorld';
Vue.use(Router);
constrouter=newRouter({ 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支持即可:
在文件里加上如下,就一切正常了
RewriteEngineOn RewriteBase/ RewriteRule^index\.html$-[L] RewriteCond%{REQUEST_FILENAME}!-f RewriteCond%{REQUEST_FILENAME}!-d RewriteRule./bank/page/index.html[L]
上面的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.LoadModulerewrite_modulelibexec/apache2/mod_rewrite.so,去掉前面的#
6.然后找到AllowOverrideNone的那行,把它改成AllowOverrideAll,来使.htaccess文件生效。
二:nginx服务器上的配置如下:
vue-cli执行打包命令:
npmrunbuild
如上进行打包,生成dist文件夹,把该文件夹下的文件直接复制到nginx服务器目录下,就可打开项目,但是只有首页可以看到的,刷新一下页面也是404了,原因和上面一样,因此需要在nginx服务器配置对所有的路径或者文件夹进行跳转,重定向到首页index.html即可:这样就能找到路由了。
nginx服务器配置如下:
1.首先登录服务器。
2.进入目录/etc/usr/local/nginx/conf/下;
执行命令:
2-1cd/etc/回车
2-2cd/usr/回车
2-3cdloacl/回车
2-4cdnginx回车
2-5cdconf回车
2-6vinginx_v4.conf进入nginx文件内新建一个项目的相关配置如下:
比如我们现在的域名地址这样访问的:http://aa.xx.com/bank/page/count,需要如下配置:
server{ listen443;#监听本机所有ip上的443端口 listen80;#监听本机所有ip上的80端口 server_nameaa.xx.com;#域名地址 access_log/data/www/logs/nginx/aa/access.logmain;#新建日志文件 includenginx_xx.conf; /*下面是多个location用于配置路由地址*/ location/{ proxy_passhttp://aa/; includenginx_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_page500502503504/502.html; location=/50x.html{ roothtml; } }
try_files指令:
语法:try_filesfile...uri或try_filesfile...=code
默认值:无
作用域:serverlocation
其作用是按顺序检查文件是否存在,返回第一个找到的文件或文件夹(结尾加斜线表示为文件夹),如果所有的文件或文件夹都找不到,会进行一个内部重定向到最后一个参数。
需要注意的是,只有最后一个参数可以引起一个内部重定向,之前的参数只设置内部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目录下cdsbin接着运行命令./nginx-sreload重启后即可生效。
4.在/data/www/logs/nginx/aa/目录下新建access.log文件。
然后nginx保存和退出命令:wq
直接退出的命令是:q
5.mac系统下自带apache2服务器,需要对apache2作反向代理;配置如下:
进入本地macapache2配置;
命令:cd/etc/apache2
命令:sudovihttpd.conf
ServerNameaa.xx.com ProxyRequestsoff HeadersetAccess-Control-Allow-Origin* Orderdeny,allow Allowfromall ProxyPasshttp://localhost:8896/ ProxyPassReversehttp://localhost:8896/ //....更多配置省略
然后进入sbin目录下启动服务sudoapachectlstart
重启命令如下sudoapachectlrestart
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路径,具体看自己的路径
6-2java开发需要配置一下:
1设置路由:/aa设置路由到/aa/index.vm
2这个include/common.vm有一个地址配置,是在disconf上配置的,你加一个
地址配置到//aa.xx.com/aa/dist上即可
总结
以上所述是小编给大家介绍的在nginx上部署vue项目(history模式)的方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对毛票票网站的支持!