Vue项目webpack打包部署到Tomcat刷新报404错误问题的解决方案


Posted in Javascript onMay 15, 2018

遇到的问题

使用webpack打包vue后,将打包好的文件,发布到Tomcat上,访问成功,但是刷新后页面报404错。

在网上查找了一下,原来是HTML5 History 模式引发的问题,具体为什么,vue官方已经给出了解释,你可以看https://router.vuejs.org/zh-cn/essentials/history-mode.html

但是看完问题又来了,官方给出的解决方案中没有说tomcat下,怎么决解。

解决方案

根据官方给出的解决方案原理

你要在服务端增加一个覆盖所有情况的候选资源:如果 URL 匹配不到任何静态资源,则应该返回同一个 index.html 页面,这个页面就是你 app 依赖的页面。

所以在tomcat服务器下你可以这么做。在打包好的项目根目录下新建一个WEB-INF文件夹,在WEB-INF中写一个web.xml。

web.xml中写:

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee
           http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd"
  version="3.1" metadata-complete="true">
  <display-name>Router for Tomcat</display-name>
  <error-page>
    <error-code>404</error-code>
    <location>/index.html</location>
  </error-page>
</web-app>

这样的目的就是一旦出现404就返回到 index.html 页面。

最后还需要配置一下你的route,配置一个覆盖所有的路由情况,然后在给出一个 404 页面。

const router = new VueRouter({
 mode: 'history',
 routes: [
  { 
    path: '*', 
    component: (resolve) => require(['./views/error404.vue'], resolve) 
  }
 ]
})

总结

以上所述是小编给大家介绍的Vue项目webpack打包部署到Tomcat刷新报404错误问题的解决方案,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
jquery向.ashx文件post中文乱码问题的解决方法
Mar 28 Javascript
js获取数组的最后一个元素
Apr 14 Javascript
JavaScript面向对象编写购物车功能
Aug 19 Javascript
$.browser.msie 为空或不是对象问题的多种解决方法
Mar 19 Javascript
angularjs指令之绑定策略(@、=、&amp;)
Apr 13 Javascript
Bootstrap按钮组实例详解
Jul 03 Javascript
vue.js使用v-pre与v-html输出HTML操作示例
Jul 07 Javascript
layui实现数据表格table分页功能(ajax异步)
Jul 27 Javascript
vue中的v-if和v-show的区别详解
Sep 01 Javascript
JS 逻辑判断不要只知道用 if-else 和 switch条件判断(小技巧)
May 27 Javascript
vue-axios同时请求多个接口 等所有接口全部加载完成再处理操作
Nov 09 Javascript
Rust中的Struct使用示例详解
Aug 14 Javascript
解决linux下node.js全局模块找不到的问题
May 15 #Javascript
vue :src 文件路径错误问题的解决方法
May 15 #Javascript
利用npm 安装删除模块的方法
May 15 #Javascript
vux uploader 图片上传组件的安装使用方法
May 15 #Javascript
使用webpack搭建react开发环境的方法
May 15 #Javascript
浅谈Node.js 沙箱环境
May 15 #Javascript
npm全局模块卸载及默认安装目录修改方法
May 15 #Javascript
You might like
不错的PHP学习之php4与php5之间会穿梭一点点感悟
2007/05/03 PHP
php文件上传表单摘自drupal的代码
2011/02/15 PHP
php返回字符串中所有单词的方法
2015/03/09 PHP
php数组转成json格式的方法
2015/03/09 PHP
php基于PDO实现功能强大的MYSQL封装类实例
2017/02/27 PHP
PHP+jQuery实现滚屏无刷新动态加载数据功能详解
2017/05/04 PHP
Javascript中的相等与不等运算
2010/04/25 Javascript
深入理解JavaScript系列(12) 变量对象(Variable Object)
2012/01/16 Javascript
Javascript实现关联数据(Linked Data)查询及注意细节
2013/02/22 Javascript
jquery实现省市select下拉框的替换(示例代码)
2014/02/22 Javascript
JavaScript时间转换处理函数
2015/04/14 Javascript
Underscore.js 1.3.3 中文注释翻译说明
2015/06/25 Javascript
JavaScript设计模式之单体模式全面解析
2016/09/09 Javascript
js如何获取网页所有图片
2017/05/12 Javascript
详解Layer弹出层样式
2017/08/21 Javascript
简单谈谈关于Angular Cli打包的事
2017/09/05 Javascript
微信小程序基于本地缓存实现点赞功能的方法
2017/12/18 Javascript
解决layui中的form表单与button的点击事件冲突问题
2018/08/15 Javascript
JavaScript中ES6规范中let和const的用法和区别
2020/08/06 Javascript
[35:34]Liquid vs Winstrike 2018国际邀请赛小组赛BO2 第一场 8.18
2018/08/19 DOTA
python使用Pycharm创建一个Django项目
2018/03/05 Python
python爬虫把url链接编码成gbk2312格式过程解析
2020/06/08 Python
Python局部变量与全局变量区别原理解析
2020/07/14 Python
使用豆瓣源来安装python中的第三方库方法
2021/01/26 Python
法国奢华女性时尚配饰网上商店:Monnier Frères
2016/08/27 全球购物
Linux如何命名文件--使用文件名时应注意
2012/01/22 面试题
出国导师推荐信
2014/01/16 职场文书
美国探亲签证邀请信
2014/02/05 职场文书
大学新生军训感言
2014/02/25 职场文书
乡镇办公室工作决心书
2014/03/11 职场文书
党员个人党性分析材料
2014/12/18 职场文书
国庆节新闻稿
2015/07/17 职场文书
关于运动会的宣传稿
2015/07/23 职场文书
财产分割协议书
2016/03/22 职场文书
关于Python OS模块常用文件/目录函数详解
2021/07/01 Python
实战Python爬虫爬取酷我音乐
2022/04/11 Python