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 相关文章推荐
javaScript - 如何引入js代码
Mar 09 Javascript
用Javascript评估用户输入密码的强度实现代码
Nov 30 Javascript
Javascript学习笔记之 函数篇(一) : 函数声明和函数表达式
Jun 24 Javascript
JS实现页面超时后自动跳转到登陆页面
Jan 19 Javascript
js去字符串前后空格的实现方法
Feb 26 Javascript
jQuery的deferred对象使用详解
Sep 25 Javascript
vue2.0中vue-cli实现全选、单选计算总价格的实例代码
Jul 18 Javascript
老生常谈js中的MVC
Jul 25 Javascript
canvas基础绘制-绚丽倒计时的实例
Sep 17 Javascript
微信小程序文章详情页面实现代码
Sep 10 Javascript
Vue.js结合bootstrap前端实现分页和排序效果
Dec 29 Javascript
新手快速入门微信小程序组件库 iView Weapp
Jun 24 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
新闻分类录入、显示系统
2006/10/09 PHP
Windows 下的 PHP-PEAR 安装方法
2010/11/20 PHP
ThinkPHP利用PHPMailer实现邮件发送实现代码
2013/09/26 PHP
php 使用curl模拟登录人人(校内)网的简单实例
2016/06/06 PHP
Aliyun Linux 编译安装 php7.3 tengine2.3.2 mysql8.0 redis5的过程详解
2020/10/20 PHP
判断脚本加载是否完成的方法
2009/05/26 Javascript
JQuery学习笔录 简单的JQuery
2012/04/09 Javascript
js中scrollHeight,scrollWidth,scrollLeft,scrolltop等差别介绍
2012/05/16 Javascript
本地图片预览(支持IE6/IE7/IE8/Firefox3)经验总结
2013/03/25 Javascript
javascript实现修改微信分享的标题内容等
2014/12/11 Javascript
javascript获取四位数字或者字母的随机数
2015/01/09 Javascript
js使用DOM操作实现简单留言板的方法
2015/04/10 Javascript
jQuery简单实现遍历数组的方法
2015/04/14 Javascript
浅谈JavaScript中null和undefined
2015/07/09 Javascript
全面解析jQuery $(document).ready()和JavaScript onload事件
2016/06/08 Javascript
基于jQuery实现仿微博发布框字数提示
2016/07/27 Javascript
django使用channels2.x实现实时通讯
2018/11/28 Javascript
用VueJS写一个Chrome浏览器插件的实现方法
2019/02/27 Javascript
vue中使用百度脑图kityminder-core二次开发的实现
2019/09/26 Javascript
微信小程序实现侧边栏分类
2019/10/21 Javascript
[08:54]《一刀刀一天》之DOTA全时刻18:十九支奔赴西雅图队伍全部出炉
2014/06/04 DOTA
[01:03:03]VP vs Mineski 2018国际邀请赛淘汰赛BO3 第一场 8.22
2018/08/23 DOTA
可用于监控 mysql Master Slave 状态的python代码
2013/02/10 Python
python实现根据ip地址反向查找主机名称的方法
2015/04/29 Python
树莓派与PC端在局域网内运用python实现即时通讯
2019/06/22 Python
new_zeros() pytorch版本的转换方式
2020/02/18 Python
使用python图形模块turtle库绘制樱花、玫瑰、圣诞树代码实例
2020/03/16 Python
python 弧度与角度互转实例
2020/04/15 Python
Python使用configparser读取ini配置文件
2020/05/25 Python
PyCharm 2020.2下配置Anaconda环境的方法步骤
2020/09/23 Python
美国一家全面的在线零售鞋类公司:SHOEBACCA
2017/01/06 全球购物
编写函数,将一个3*3矩阵转置
2013/10/09 面试题
高中的职业生涯规划书
2013/12/28 职场文书
商务邀请函范文
2014/01/14 职场文书
MyBatis XPathParser解析器使用范例详解
2022/07/15 Java/Android
在windows server 2012 r2中安装mysql的详细步骤
2022/07/23 Servers