本文主要解决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问题解决相关推荐

  1. 在nginx上部署vue项目(history模式);

    在nginx上部署vue项目(history模式): vue-router 默认是hash模式,使用url的hash来模拟一个完整的url,当url改变的时候,页面不会重新加载.但是如果我们不想has ...

  2. 在nginx上部署vue项目(history模式)--demo实列;

    转载地址:https://www.cnblogs.com/573734817pc/p/11057677.html 在很早之前,我写了一篇 关于 在nginx上部署vue项目(history模式) 但是 ...

  3. history模式 nginx配置_nginx反向代理部署vue项目(history模式)的方法

    前言: 根据标题我们要区分出两个信息 1. history 模式部署 ( vue的路由模式如果使用history,刷新会报404错误.) 2. Nginx 做反向代理 问题1思考: vue-route ...

  4. 解决Vue的history模式刷新页面出现404的问题

    解决Vue的history模式刷新页面出现404的问题 路由的两种工作模式 (一).hash模式 地址中永远带着#号,不美观 若以后将地址通过第三方手机app分享,若app校验严格,地址会被标记为不合 ...

  5. vue使用history模式页面空白

    之前负责了一个项目,使用的是vue.为了避免在地址链接的时候出现问题后端要求去掉#号,也就是使用history模式. 更改history模式后打包部署后发现页面空白.查询了下官网的文档资料https: ...

  6. nginx导致vue设置history模式下的请求丢失参数

    nginx导致vue设置history模式下的请求丢失参数 问题描述: 当访问下面的路径时参数会丢失: http://ip/vuecay/path1/path2?name=cay 演示效果: 可以看到 ...

  7. Vue路由history模式踩坑记录:nginx配置解决404问题

    问题背景: vue-router 默认是hash模式,使用url的hash来模拟一个完整的url,当url改变的时候,页面不会重新加载.但是如果我们不想hash这种以#号结尾的路径时候的话,我们可以使 ...

  8. 新来的前端小姐姐问:Vue路由history模式刷新页面出现404问题

    摘要:vue-router 默认 hash 模式 -- 使用 URL 的 hash 来模拟一个完整的 URL,于是当 URL 改变时,页面不会重新加载. 本文分享自华为云社区<学习Vue Rou ...

  9. Vue改用history模式后Nginx代理报404

    由于以前VUE采用hash模式: hash -- 即地址栏 URL 中的 # 符号(此 hash 不是密码学里的散列运算) 比如:http://abc.example.com/abc/#/hello, ...

最新文章

  1. ACM OnlineJudge网站汇总
  2. Oracle 数据库直接执行本地sql文件、sql脚本实例演示
  3. 深度学习核心技术精讲100篇(二)-图网络中的社群及社群发现算法
  4. 【采用】规则引擎Pyke与PyClips对比研究报告(高大上啊,第一次听说pyke和pyclips这俩词~)
  5. RabbitMQ RPC远程调用模式
  6. Win7远程桌面不能连接的解决方案
  7. C语言2011计算机二级c语言考点:c语言的基础知识
  8. QPW 提现申请单表(暂时不做)(tf_cash_apply)
  9. jQuery常用操作
  10. 梅宏院士:步入软件定义的时代
  11. Java用freemarker导出word
  12. DE19 Introduction to the Laplace Transform
  13. 江苏计算机云服务,云呐|江苏企业机房环境动环监控服务商系统智能监测
  14. 一张思维导图带你快速了解深度学习推荐系统
  15. 在禁用uac_禁用仅管理员用户帐户控制(UAC)
  16. OpenSSL 常用函数——证书操作
  17. pca人脸特征降维的过程理解及matlab编程实现
  18. vue下载sass依赖
  19. 基于rrweb框架对web 页面录制与回放
  20. 将一颗树反转为其镜像

热门文章

  1. php srs api,srs 身份认证
  2. 吕梁市人民政府刘晋萍副市长率团访问启迪控股
  3. oracle裁员原因_甲骨文中国裁员是什么情况? 甲骨文中国裁员的原因是什么?...
  4. 两名老人接力营救轻生女子一人溺亡
  5. APNS推送证书生成与验证
  6. matlab访问被拒绝,安装MATLAB拒绝访问问题的解决方法
  7. JavaScript 精选:哪些能提高开发效率的es6 新语法糖
  8. github Topic 功能 | github 常用条件查询
  9. Servlet总结待续
  10. 《电脑音乐制作实战指南:伴奏、录歌、MTV全攻略》——1.3 将下载的MIDI歌曲制作成MIDI音乐伴奏...