Vue项目History模式404问题解决
本文主要解决Vue项目使用History模式发布到服务器Nginx上刷新页面404问题。(由于每个项目的情况都不尽相同,本方案已经完美解决本在所使用项目,具体情况可能还需要修改。)
1.项目背景分析
本人是Java后台开发,Vue其实使用也没有多久,只能说简单了解。发现问题的时候其实也一头雾水,第一思想就是百度看别人的思路。
1.1 查看项目打包后文件
首先看看项目打包后文件内容,看看有没有什么能突破的地方。文件目录如下:
打眼一看可以发现,主要的可能就是这个index.html文件,内容如下:
<!DOCTYPE html>
<html lang="en"><head><meta charset="utf-8"><title>系统管理</title><meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no"><link rel="shortcut icon" type="image/x-icon" href="logo.png">
<link rel="shortcut icon" href="logo.png"></head><body><div id="app"></div>
<script type="text/javascript" src="manifest.js?89b5083667173048a500"></script><script type="text/javascript" src="vendor.js?9eae337435ee1b63d5cd"></script><script type="text/javascript" src="index.js?38915745c7ed8b9143db"></script>
</body></html>
1.在之前百度的时候看到了一个信息,就是引入js文件使用scr的时候,如果前面带/是绝对路径,在思考是不是这个问题。
2.百度的时候大部分信息都是说修改Nginx配置文件。
2.问题解决
既然大致思路都有了,那么就开始尝试去解决一下。
2.1 更改Vue打包配置文件
修改webpack.config.js文件,这个是Vue-cli打包文件配置,使其打包后让index.html文件引用路径为绝对路径。webpack.config.js内容如下(每个项目打包配置均不同,这个配置仅仅是我使用的项目):
const resolve = require('path').resolve
const webpack = require('webpack')
const HtmlWebpackPlugin = require('html-webpack-plugin')
const url = require('url')
const publicPath = '/'module.exports = (options = {}) => ({entry: {vendor: './src/vendor',index: './src/main.js'},output: {path: resolve(__dirname, 'dist'),filename: options.dev ? '[name].js' : '[name].js?[chunkhash]',chunkFilename: '[id].js?[chunkhash]',publicPath: options.dev ? '/assets/' : publicPath},module: {rules: [{test: /\.vue$/,use: ['vue-loader']},{test: /\.js$/,use: ['babel-loader'],exclude: /node_modules/},{test: /\.css$/,use: ['style-loader', 'css-loader', 'postcss-loader']},{test: /\.(png|jpg|jpeg|gif|eot|ttf|woff|woff2|svg|svgz)(\?.+)?$/,use: [{loader: 'url-loader',options: {limit: 10000}}]}]},plugins: [new webpack.optimize.CommonsChunkPlugin({names: ['vendor', 'manifest']}),new HtmlWebpackPlugin({template: 'src/index.html',favicon: 'src/logo.png' })],resolve: {alias: {'~': resolve(__dirname, 'src')},extensions: ['.js', '.vue', '.json', '.css']},devServer: {host: '127.0.0.1',port: 8010,proxy: {'/api/': {target: 'http://127.0.0.1:8080',changeOrigin: true,pathRewrite: {'^/api': ''}}},historyApiFallback: {index: url.parse(options.dev ? '/assets/' : publicPath).pathname}},devtool: options.dev ? '#eval-source-map' : '#source-map'
})
再次打包后,查看index.html,内容如下:
<!DOCTYPE html>
<html lang="en"><head><meta charset="utf-8"><title>系统管理</title><meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no"><link rel="shortcut icon" type="image/x-icon" href="logo.png">
<link rel="shortcut icon" href="/logo.png"></head><body><div id="app"></div>
<script type="text/javascript" src="/manifest.js?f7d4b2121bc37e262877"></script><script type="text/javascript" src="/vendor.js?9eae337435ee1b63d5cd"></script><script type="text/javascript" src="/index.js?51954197166dd938b54e"></script></body></html>
从index.html可以看出已经变成了绝对路径。
2.2 修改Nginx配置
修改nginx.conf配置文件,代码如下:
worker_processes 1;events {worker_connections 1024;
}http {include mime.types;default_type application/octet-stream;sendfile on;keepalive_timeout 65;server {listen 80;server_name localhost;## 指向vue打包后文件位置root /opt/nginx/dist/;## 拦截根请求,例如http://localhostlocation / {try_files $uri $uri/ /index.html;}## 拦截带有tms-monitor的请求,例如http://localhost/tms-monitor/adminlocation ^~/tms-monitor{if (!-e $request_filename) {rewrite ^/(.*) /index.html last;break;}}#error_page 500 502 503 504 /50x.html;location = /50x.html {root html;}}
}
3.总结
上述配置完成后,打包Vue项目,重启Nginx再次刷新就不会在有404的现象了。(再次申明:以上只是针对本人所在的项目,不一定使用所有情况。)
Vue项目History模式404问题解决相关推荐
- 在nginx上部署vue项目(history模式);
在nginx上部署vue项目(history模式): vue-router 默认是hash模式,使用url的hash来模拟一个完整的url,当url改变的时候,页面不会重新加载.但是如果我们不想has ...
- 在nginx上部署vue项目(history模式)--demo实列;
转载地址:https://www.cnblogs.com/573734817pc/p/11057677.html 在很早之前,我写了一篇 关于 在nginx上部署vue项目(history模式) 但是 ...
- history模式 nginx配置_nginx反向代理部署vue项目(history模式)的方法
前言: 根据标题我们要区分出两个信息 1. history 模式部署 ( vue的路由模式如果使用history,刷新会报404错误.) 2. Nginx 做反向代理 问题1思考: vue-route ...
- 解决Vue的history模式刷新页面出现404的问题
解决Vue的history模式刷新页面出现404的问题 路由的两种工作模式 (一).hash模式 地址中永远带着#号,不美观 若以后将地址通过第三方手机app分享,若app校验严格,地址会被标记为不合 ...
- vue使用history模式页面空白
之前负责了一个项目,使用的是vue.为了避免在地址链接的时候出现问题后端要求去掉#号,也就是使用history模式. 更改history模式后打包部署后发现页面空白.查询了下官网的文档资料https: ...
- nginx导致vue设置history模式下的请求丢失参数
nginx导致vue设置history模式下的请求丢失参数 问题描述: 当访问下面的路径时参数会丢失: http://ip/vuecay/path1/path2?name=cay 演示效果: 可以看到 ...
- Vue路由history模式踩坑记录:nginx配置解决404问题
问题背景: vue-router 默认是hash模式,使用url的hash来模拟一个完整的url,当url改变的时候,页面不会重新加载.但是如果我们不想hash这种以#号结尾的路径时候的话,我们可以使 ...
- 新来的前端小姐姐问:Vue路由history模式刷新页面出现404问题
摘要:vue-router 默认 hash 模式 -- 使用 URL 的 hash 来模拟一个完整的 URL,于是当 URL 改变时,页面不会重新加载. 本文分享自华为云社区<学习Vue Rou ...
- Vue改用history模式后Nginx代理报404
由于以前VUE采用hash模式: hash -- 即地址栏 URL 中的 # 符号(此 hash 不是密码学里的散列运算) 比如:http://abc.example.com/abc/#/hello, ...
最新文章
- ACM OnlineJudge网站汇总
- Oracle 数据库直接执行本地sql文件、sql脚本实例演示
- 深度学习核心技术精讲100篇(二)-图网络中的社群及社群发现算法
- 【采用】规则引擎Pyke与PyClips对比研究报告(高大上啊,第一次听说pyke和pyclips这俩词~)
- RabbitMQ RPC远程调用模式
- Win7远程桌面不能连接的解决方案
- C语言2011计算机二级c语言考点:c语言的基础知识
- QPW 提现申请单表(暂时不做)(tf_cash_apply)
- jQuery常用操作
- 梅宏院士:步入软件定义的时代
- Java用freemarker导出word
- DE19 Introduction to the Laplace Transform
- 江苏计算机云服务,云呐|江苏企业机房环境动环监控服务商系统智能监测
- 一张思维导图带你快速了解深度学习推荐系统
- 在禁用uac_禁用仅管理员用户帐户控制(UAC)
- OpenSSL 常用函数——证书操作
- pca人脸特征降维的过程理解及matlab编程实现
- vue下载sass依赖
- 基于rrweb框架对web 页面录制与回放
- 将一颗树反转为其镜像
热门文章
- php srs api,srs 身份认证
- 吕梁市人民政府刘晋萍副市长率团访问启迪控股
- oracle裁员原因_甲骨文中国裁员是什么情况? 甲骨文中国裁员的原因是什么?...
- 两名老人接力营救轻生女子一人溺亡
- APNS推送证书生成与验证
- matlab访问被拒绝,安装MATLAB拒绝访问问题的解决方法
- JavaScript 精选:哪些能提高开发效率的es6 新语法糖
- github Topic 功能 | github 常用条件查询
- Servlet总结待续
- 《电脑音乐制作实战指南:伴奏、录歌、MTV全攻略》——1.3 将下载的MIDI歌曲制作成MIDI音乐伴奏...