Vue项目构建后通过Nginx/SpringBoot/Express/Egg发布

构建

当项目开发完毕,只需要运行一行命令就可以打包你的应用:

$ yarn build
or
$ npm run build

由于 Ant Design Pro 使用的工具 Vue-cli3 已经将复杂的流程封装完毕,构建打包文件只需要一个命令 yarn build 或 npm run build,构建打包成功之后,会在根目录生成 dist 文件夹,里面就是构建打包好的文件,通常是 *.js*.cssindex.html 等静态文件,也包括了项目根的 public/ 下的所有文件。

如果需要自定义构建,比如指定 dist 目录等,可以通过 /vue.config.js 进行配置,详情参看:Vue-cli3 配置。

前端路由与服务端的结合

Ant Design Pro 使用的 Vue-Router 支持两种路由方式:browserHistory 和 hashHistory 可以参考文档 Vue-Router URL 模式。
可以在 src/router/index.js 中进行配置选择用哪个方式:

import Vue from 'vue'
import Router from 'vue-router'
import { constantRouterMap } from '@/config/router.config'Vue.use(Router)export default new Router({mode: 'history', // 默认是 history 可以改为 hashbase: process.env.BASE_URL,scrollBehavior: () => ({ y: 0 }),routes: constantRouterMap
})

hashHistory 使用如 https://cdn.com/#/users/123 这样的 URL,取井号后面的字符作为路径。browserHistory 则直接使用 https://cdn.com/users/123 这样的 URL。使用 hashHistory 时浏览器访问到的始终都是根目录下 index.html。使用 browserHistory 则需要服务器做好处理 URL 的准备,处理应用启动最初的 / 这样的请求应该没问题,但当用户来回跳转并在 /users/123 刷新时,服务器就会收到来自 /users/123 的请求,这时你需要配置服务器能处理这个 URL 返回正确的 index.html。如果你能控制服务端,我们推荐使用 browserHistory

使用 nginx

nginx 作为最流行的 web 容器之一,配置和使用相当简单,只要简单的配置就能拥有高性能和高可用。推荐使用 nginx 托管。示例配置如下:

server {listen 80;# gzip configgzip on;gzip_min_length 1k;gzip_comp_level 9;gzip_types text/plain application/javascript application/x-javascript text/css application/xml text/javascript application/x-httpd-php image/jpeg image/gif image/png;gzip_vary on;gzip_disable "MSIE [1-6]\.";root /usr/share/nginx/html;location / {# 用于配合 browserHistory 使用try_files $uri $uri/ /index.html;# 如果有资源,建议使用 https + http2,配合按需加载可以获得更好的体验 # rewrite ^/(.*)$ https://preview.pro.loacg.com/$1 permanent;}location /api {proxy_pass https://preview.pro.loacg.com;proxy_set_header   X-Forwarded-Proto $scheme;proxy_set_header   Host              $http_host;proxy_set_header   X-Real-IP         $remote_addr;}
}
server {# 如果有资源,建议使用 https + http2,配合按需加载可以获得更好的体验 listen 443 ssl http2 default_server;# 证书的公私钥ssl_certificate /path/to/public.crt;ssl_certificate_key /path/to/private.key;location / {# 用于配合 browserHistory 使用try_files $uri $uri/ /index.html;}location /api {proxy_pass https://preview.pro.loacg.com;proxy_set_header   X-Forwarded-Proto $scheme;proxy_set_header   Host              $http_host;proxy_set_header   X-Real-IP         $remote_addr;}
}

使用 spring boot

Spring Boot 是使用最多的 java 框架,只需要简单的几步就可以与 Ant Design Pro 进行整合。
首先运行 build
$ yarn build or $ npm run build
然后将编译之后的文件复制到 spring boot 项目的 /src/main/resources/static 目录下。
重新启动项目,访问 http://localhost:8080/ 就可以看到效果。
为了方便做整合,最好使用 hash 路由。如果你想使用 browserHistory ,你需要创建一个 controller ,并添加如下代码:

@RequestMapping("/api/**")
public ApiResult api(HttpServletRequest request, HttpServletResponse response){return apiProxy.proxy(request, reponse);
}@RequestMapping(value="/**", method=HTTPMethod.GET)
public String index(){return "index"
}

注意 pro 并没有提供 java 的 api 接口实现,如果只是为了预览 demo,可以使用反向代理到 https://preview.pro.loacg.com

使用 express

express 的例子

app.use(express.static(path.join(__dirname, 'build')));app.get('/*', function (req, res) {res.sendFile(path.join(__dirname, 'build', 'index.html'));
});

使用 egg

egg 的例子

// controller
exports.index = function* () {yield this.render('App.jsx', {context: {user: this.session.user,},});
};// router
app.get('home', '/*', 'home.index');

关于路由更多可以参看 Vue-Router 文档 。

Vue项目构建后通过Nginx/SpringBoot/Express/Egg发布相关推荐

  1. VUE项目打包后posy代理失效Nginx解决

    vue项目打包dist部署Nginx Vueproxy代理失效Nginx解决办法 vue.config.js devServer: {proxy: {"/oauth2": {tar ...

  2. Vue项目构建开发入门

    Vue项目构建开发入门 开篇:Vue CLI 3 项目构建基础 大家好,当你点进这个标题,开始阅读本章的时候,说明你对 Vue.js 是充满好奇心和求知欲的.我之前写过一篇文章,这样评价 Vue.js ...

  3. 多个vue项目生产环境下NGINX配置文件

    多个vue项目生产环境下NGINX配置文件 使用场景 1.多个前端项目 2.多个后端项目 3.修改nginx配置后端接口转发路径 4.反向代理 某个目录下 带特定后缀名的文件 5.vue3项目 使用前 ...

  4. Vue项目打包后js文件压缩

    前言 这段时间因为免费试用了https://free.aliyun.com/一台阿里云的服务器,配置是 2核4G 2M, 因为带宽太低了,每次在第一次加载的时候太慢了,通过F12调试,发现主要是因为加 ...

  5. 关于vue项目打包后提示图片文件路径错误的解决方法

    vue项目打包后在production模式下提示图片 '404(not found),在dev环境下好好的,打包了就提示这个错误.这是为什么呢,以前第一次使用vue-cli构建项目的的时候只有两个图片 ...

  6. Vue项目打包后不能正常显示页面

    项目场景: 通过 Vue CLI 创建的 vue 项目,编写完项目后,通过 npm run bulid 对项目进行打包,再把打包得到的内容(dist文件夹)交给后端部署到服务器上. 问题描述: 对 v ...

  7. php项目index页面空白,如何解决vue项目打包后打开页面空白的问题

    这篇文章主要介绍了vue项目打包后打开空白解决办法,内容挺不错的,现在分享给大家,也给大家做个参考. 网上很多说自己的VUE项目通过Webpack打包生成的list文件,放到HBulider打包后,通 ...

  8. vue 项目打包后 浏览器 F12 在source 下不显示 webpack 包

    vue 项目打包后 浏览器 F12 在source 下不显示 webpack 包,度娘上好多说的是 在 vue.config.js 配置 productionSourceMap: false 即可,然 ...

  9. (javascript)vue项目打包后,写的覆盖element的样式无效了。这是什么原因?

    问题: (javascript)vue项目打包后,写的覆盖element的样式无效了.这是什么原因?描述: 在开发模式模式下,写的覆盖样式都有效,打包后就无效,请问下是什么原因? main.js里的c ...

最新文章

  1. 数学好=编程能力强?MIT新发现:二者激活大脑区域并不同
  2. hdu2.1.1 最小公倍数
  3. 上汽乘用车-大数据岗位面试(失败经历)
  4. .NET Core实战项目之CMS 第八章 设计篇-内容管理极简设计全过程
  5. 如何将商业第三方文物整合到您的Maven版本中
  6. 移动端开发语言的未来的猜想#华为云·寻找黑马程序员#
  7. [Angularjs]视图和路由(一)
  8. Windows系统服务器中安装Redis服务
  9. GitHub常用优秀开源Android项目
  10. 我想开发一个小程序,大概需要多少钱?
  11. 成功解决android 网络视频边下载变播放。
  12. java获取Ip工具类
  13. 【项目实战】基于STM32单片机的智能小车设计(有代码)
  14. python npv 计算公式_Python numpy 中常用的数据运算
  15. 机器学习实战(3)——分类
  16. 斩波稳定(自稳零)精密运算放大器
  17. metaboxs.php,php – WooCommerce:将自定义Metabox添加到管理员订单页面
  18. 502 bad gateway这是什么意思_2020年11月11日将出现“水星西大距”,这是什么意思?...
  19. 使用OpenCV调用摄像头
  20. NP完全问题与近似算法:贪婪策略|Python实现

热门文章

  1. 你知道他们的输出结果吗?
  2. 浅析BMP位图文件结构(含Demo)[转]
  3. WordPress 主题教程 #6:侧边栏
  4. Shell编程:简洁的 Bash Programming 技巧
  5. Bootstrap ScrollSpy 用法
  6. 解决Ubuntu vim 中文乱码
  7. php clean html 可以设置过滤及保留属性
  8. php 操作数组 (合并,拆分,追加,查找,删除等)
  9. firebug for IE6+, Firefox, Opera, Safari and Chrome
  10. jquery user interface