vue采用history路由的服务器部署问题

发现部署问题

在部署的时候发现打开的页面是空白

之前部署原理

之前的页面都是作为静态文件形式打包上传到服务器上

http://www.xiedashuaige.cn/bolg2.0/#/home

就和这个页面一样,我其实上只有一个页面/bolg2.0

然后前端的路由切换都是根据后面的哈希值来变化

然后不同的哈希值指向的页面还是/bolg2.0页面

所以就放在静态目录都可以访问

部署问题解析

然后我用了history路由后打开的页面页面的时候发现服务器报404

http://www.xiedashuaige.cn/BolgAdmin/admin

首先我在服务器上对应的静态页面是/BolgAdmin页面

但是我前端路由的首页是/BolgAdmin/admin这个页面

但是服务器以为/BolgAdmin/admin是单独的一个页面资源

然后又找不到这个资源,所以就会报404

分析问题

然后我想了两种解决方法

  • 一种就是在服务器上设置一个转发,把所有/BolgAdmin下面的子路由全部转发到/BolgAdmin页面下,但是对于服务器的我不太了解
  • 通过node写一个后端就像http://www.xiedashuaige.cn:3000一样,然后访问http://www.xiedashuaige.cn:3000/BolgAdmin/admin的页面全部转发到http://www.xiedashuaige.cn:3000/BolgAdmin上面,这样就可以通过node来实现,比使用apache来改应该简单一些,我还在研究中。。

解决问题

正好在学koa就用koa搭建了一个服务器,代码如下

const fs = require('fs')
const Koa = require('koa')
const route = require('koa-route')
const path = require('path')
const static = require('koa-static')
const app = new Koa()

const main = ctx => {
  ctx.response.type = 'html'
  ctx.response.body = fs.createReadStream(path.join(__dirname,  '/index.html'))
}
const toMain = ctx => {
  ctx.response.redirect('/admin/')
}

const staticFile = static(path.join(__dirname, '/'))

app.use(staticFile)
app.use(route.get('/', toMain))
app.use(route.get('/admin/*', main))

app.listen(3001)

其实就是搭建了一个静态目录,然后把/目录重定向到/admin目录下,然后把/admin/*目录全部打开index文件

然后这样就可以打开vue history模式的单页面应用了

结语

其实吧最后还是有一个问题,是针对于我这个项目的。我这个项目使用了vue的代理跨域,然后后端是用go写的跑在另外一个端口,所以最后直接把打包后的文件让go来做相同的处理,其实主要是了解了一波history模式会出现的问题咯。

原文地址:https://www.cnblogs.com/xiedashuaige/p/9211425.html

时间: 2024-10-09 00:24:21

vue采用history路由的服务器部署问题的相关文章

Vue.js项目在apache服务器部署后,刷新404的问题

原因是vue-router 使用了路由的 history 模式,这种模式充分利用 history.pushState API 来完成 URL 跳转而无须重新加载页面. const router = new VueRouter({ mode: 'history', routes: [...] }) 需要在服务端增加一个覆盖所有情况的候选资源:如果 URL 匹配不到任何静态资源,则应该返回同一个 index.html 页面,这个页面就是你 app 依赖的页面. 解决方案 在项目目录下新建文件.hta

win10系统本地iis服务器部署vue.js项目

1.前端框架一般依赖node.js,我们首先要安装node.js.请参考: http://www.cnblogs.com/wuac/p/6381819.html to:安装好node.js后npm也安装OK了 , 自己在设置一下环境变量路径配置 自行百度.. 查看node版本命令:node -v 查看npm版本命令: npm -v 2.npm 的源都在国外的地址,安装起来特别慢,这里利用淘宝的镜像服务器. 安装命令为:npm install -g cnpm --registry=https://

Laravel+vue实现history模式URL可行方案

项目:laravel + vue 实现前后端分离.vue-router 默认 hash 模式 -- 使用 URL 的 hash 来模拟一个完整的 URL,于是当 URL 改变时,页面不会重新加载. hash URL 例如:http://yoursite.com/#/user/id. history 模式时,URL就像正常的 url,例如 http://yoursite.com/user/id. 没有特别的要求的话,hash模式亦正常访问.好嘛,产品要求URL要像正常那样的 -- history模

vue-小爱ADMIN系列文章(二):微信微博等分享,国际化,前端性能优化,nginx服务器部署

最近在做我的小爱ADMIN后台管理系统,结合当前市场后台管理系统对相关功能的需求,我又开始新增了一些新的功能和组件,如分享功能组件,项目国际化功能:项目完成后,部署在nginx服务器,发现首次访问的速度特别慢,严重的影响了用户体验,因此,我又开始进行了一系列的前端性能优化;以及将优化后的项目部署到nginx服务器二级子目录的注意细节. 效果演示地址 github地址 分享功能 背景说明 用微信,微博等做网站的第三方登录及用微信和支付宝进行支付,都需要注册开发者账号和添加网站应用,比较麻烦.另外,

Lync Server 2013 标准版部署(十)边缘服务器部署先决条件

现将需要部署边缘服务器的操作系统安装完成,进行初始化配置:防火墙.Windows不行.注:Lync Server 2013 边缘服务器部署在DMZ区域,不推荐加域. Lync Server 2013 边缘服务器的网络适配器配置有多种方式,需要考虑边缘服务器上的三个服务采用几个公网IP地址进行发布&公网IP的数量情况. 如果公网IP地址不是很富裕,可以采用一个公网IP地址对边缘服务器上的三个服务进行发布(采用不同的端口):使用一个公网IP地址进行发布,需要两个网络适配器: 如果公网IP地址富裕,可

分享一个大型进销存供应链项目(多层架构、分布式WCF多服务器部署、微软企业库架构)

分享一个大型进销存供应链项目(多层架构.分布式WCF多服务器部署.微软企业库架构) 这是一个比较大型的项目,准备开源了.支持N家门店同时操作.远程WCF+企业库5.0实现. 这块应该算是库存模块中的核心模块了,因为该块的业务逻辑比较多,比较繁琐,大致讲讲业务逻辑吧,大致的逻辑为:出库单/出库单-->填写订单-->出库/入库-->修改库存信息,按照这个顺序来完成入库出库,顺序不能颠倒,同时还要实现订单的删除,修改,在修改库存信息时由于表和表之间有很多的外键关系,所以要同时删除多张表中含有删

HappyAA服务器部署笔记1(nginx+tomcat的安装与配置)

这是本人的服务器部署笔记.文章名称叫"部署笔记1"的原因是之后我对这个进行了改进之后,会有"部署笔记2","部署笔记3"...循序渐进,估计应该是这样的:) 概述与设计 nginx安装 nginx基本使用 nginx的配置 tomcat的安装与配置 部署程序 待续 概述与设计 主机使用阿里云主机,配置不高,但前期应该够用,以后有需要的话再升级. 主要的业务逻辑是用java实现,并用tomcat承载,但大家知道tomcat并不适合作为大量的静态资源

linux服务器部署tomcat和Nginx

项目需要,申请了三台测试机器,好在测试机里面光秃秃的什么都没有,我就可以好好的学习一把玩一把了!接下来以图文的形式讲一下我所碰到的坑以及小小的收获吧! 一.准备工作 首先你得有一台可以玩的linux服务器,知道用户名和密码,然后你需要在windows电脑上安装两个可以连上linux服务器的工具,Xshell 5和Xftp 5,安装教程不多说,补图说明如何连上服务器: xshell连接界面如下,输入好主机ip后点击确定,xshell会弹出窗口输入用户名和密码即可连接成功! xftp连接界面如下,填

jenkins主从服务器部署

先做好准备活动: 1.主(master).从(slave)服务器上JDK的安装和环境变量的配置 2.主(master).从(slave)服务器上maven的安装,环境变量的配置 接下来: 1.下载最新版的jenkins(我的是1.567的),下载下来是个war包,直接扔tomcat下就可以运行了. 2.打开jenkins(10.0.0.10:8080/jenkins/)ip和端口号写你自己的就可以了 3.新建一个job,我建的是一个maven2/3的项目  4.暂时从源码管理开始配置,(其余配置