代理启动前端dist包

目录

前言:

主要技术:

步骤

1、新建代理文件proxy.js

2、安装依赖:

3、启动代理

4、访问

后记优化


前言:

开发过程中需要频繁和前端进行联调,前端同事只有一个,需要对接的后端却有好几个,导致前端分身无术,拖慢开发效率,于是让前端同事打包一份dist,这篇文章主要来讲解如何在本地启动前端包后进行联调

主要技术:

后端是springcloud(本篇讲的也是如何请求到网关)、前端用的vue

步骤

1、新建代理文件proxy.js

解压dist文件,打开后,可以看到css、js等文件夹,如下图所示

在同级目录新建代理文件proxy.js

javascript 复制代码
const express = require('express');
const { createProxyMiddleware } = require('http-proxy-middleware');

const app = express();
app.use(express.static(__dirname));

// 关键:代理 /api 到网关 5001
app.use('/api', createProxyMiddleware({
  target: 'http://127.0.0.1:5001',
  changeOrigin: true
}));


// 端口 3001
app.listen(3001, () => {
  console.log('=====================================');
  console.log('✅ 前端启动:http://127.0.0.1:3001');
  console.log('✅ 已代理:/api -> 5001');
  console.log('=====================================');
});

我本地启动的网关是5001:

前端请求的接口格式是api/```,;如果接口格式不一样需要改相对应的上述js

2、安装依赖:

打开命令行进入dist文件夹后运行:

npm install express http-proxy-middleware

3、启动代理:

还是在命令行中运行

node proxy.js

4、访问

在日志中看到如下信息:点开链接访问

至此就成功啦!

后记优化:

启动后的前端进行页面刷新后页面会消失,页面显示报Cannot GET 【你的接口地址】

javascript 复制代码
const express = require('express');
const path = require('path');
const app = express();

// 静态资源
app.use(express.static(__dirname));

// ------------------------------
// 原来的代理
// ------------------------------
app.use('/api', require('http-proxy-middleware').createProxyMiddleware({
  target: 'http://127.0.0.1:5001',
  changeOrigin: true
}));

// ------------------------------
// 修复刷新 404(无通配符,不报错)
// ------------------------------
app.use((req, res) => {
  res.sendFile(path.join(__dirname, 'index.html'));
});

// 端口 3001
app.listen(3001, () => {
  console.log('=====================================');
  console.log('✅ 前端启动:http://127.0.0.1:3001');
  console.log('✅ 接口代理:5001');
  console.log('✅ 刷新正常');
  console.log('=====================================');
});
相关推荐
zmsofts1 小时前
Maven核心能力深度解析:从项目管理到扩展机制
java·python·maven
段ヤシ.1 小时前
回顾Java知识点,面试题汇总Day5(持续更新)
java·开发语言
不会C语言的男孩1 小时前
C++ SLTL编程
java·开发语言·c++
java修仙传1 小时前
Java 实习日记:从业务表关系到节点价格分析接口改造
java·开发语言·实习
码农-阿杰1 小时前
Java 线程等待唤醒机制深度解析:synchronized、ReentrantLock、LockSupport 底层实现对比
java·开发语言·c++
数字化顾问2 小时前
(122页PPT)企业数字化IT架构蓝图规划设计方案(附下载方式)
java·运维·架构
不是光头 强2 小时前
Spring Boot 多线程场景下 i18n 国际化失效问题排查与解决
java·开发语言·springboot
星恒随风2 小时前
四天学完前端基础三件套(JavaScript篇)
开发语言·前端·javascript·笔记
guslegend2 小时前
第9节:前端工程与一键启动
前端·大模型·状态模式·ai编程