代理启动前端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('=====================================');
});
相关推荐
kyriewen13 小时前
2026 年了,还在用 Node.js?Bun 迁移实战:20 分钟搞定,附踩坑记录
前端·javascript·node.js
Flynt14 小时前
从Spring Boot 4.0升到4.1,我在Maven和gRPC上栽了跟头
java·spring boot·后端
青山Coding15 小时前
Cesium应用(八):物体运动的实现思路
前端·cesium
plainGeekDev15 小时前
Activity 间传值 → Navigation 参数
android·java·kotlin
用户416596736935515 小时前
Android WebView 加载 file:// 离线页面调试教程
android·前端
Asmewill15 小时前
curl命令学习笔记一
前端
我是一只快乐的小螃蟹15 小时前
1.2 ArrayList 源码解析
前端
星栈15 小时前
我用 Rust + Dioxus 做了个全栈跨平台笔记应用:再把新建、编辑和交付补上
前端·rust·前端框架
plainGeekDev15 小时前
onActivityResult → ActivityResult API
android·java·kotlin
Sunia15 小时前
《AgentX 专栏》10-生产部署:3台2C4G云服务器把企业级Agent真正跑起来的完整方案
java·架构