项目中用运行时 config.json 动态配置后端地址(精华版)

文章目录


前言

局域网多现场部署(每个项目后端 IP 不同),但不希望每次打包都改 .env 或重建。目标是:运行时可配置 API_BASE_URL,前端无需重打包即可切换后端地址

把可变的后端地址放到 public/config.json(运行时文件),启动时读取并缓存;axios 在请求时从缓存读取 API_BASE_URL 并注入到每次请求的 baseURL 中


无需重打包:部署时只改 dist/config.json。

兼容浏览器部署:不用改路由器或 DNS

支持现场临时覆盖(localStorage):方便运维即时调试。

简单、工程化、易维护。`

一、public/config.json(部署时修改)?

javascript 复制代码
{
  "API_BASE_URL": "http://192.168.1.100:8080"
}

放在 public/,打包后会原样复制到 dist/config.json,浏览器可通过 /config.json 读取。

二、main.js(运行时加载 + 缓存)

1、代码

javascript 复制代码
import Vue from 'vue'
import App from './App.vue'
import router from "@/router"
import axios from "axios";
import store from './store/index';
import scroll from 'vue-seamless-scroll'
// import getMqttClient  from '@/utils/mqttClient';
import { loadRuntimeConfig } from '@/utils/config' 
Vue.prototype.$store = store
import '../src/plugins/element'
Vue.use(scroll)

Vue.prototype.$axios = axios
// const mqttClient = getMqttClient({ clientId: "dp_" + store.state.login.publickey });
// const mqttClient = new MQTT({
//   topic: `zh-ylgl/dsj/${this.login.privatekey}`,
//   clientId: "dp_" + this.login.publickey,
// });
// mqttClient.init();
// 连接 MQTT 并订阅指定的主题
// mqttClient.link();
// Vue.prototype.$mqttClient = mqttClient;
Vue.config.productionTip = false
loadRuntimeConfig().then(() => {
  new Vue({
    router,
    store,
    render: h => h(App),
  }).$mount('#app')
})

2.引入

javascript 复制代码
// src/utils/config.js
let runtimeConfig = null

export function loadRuntimeConfig () {
  return fetch('/config.json?_=' + Date.now())
    .then(res => res.json())
    .then(cfg => {
      runtimeConfig = cfg
      return cfg
    })
}

export function getRuntimeConfig () {
  return runtimeConfig || {}
}

3、使用

javascript 复制代码
// utils/request.js
import axios from 'axios';
import { Message } from 'element-ui'; // 引入 Element UI 的消息组件
import { getRuntimeConfig } from '@/utils/config'



// 创建 axios 实例
const instance = axios.create({
  timeout: 5000,
});

// 请求拦截器
instance.interceptors.request.use(config => {
    const cfg = getRuntimeConfig()
  if (cfg && cfg.API_BASE_URL) {
    config.baseURL = cfg.API_BASE_URL
    console.log("cfg.API_BASE_URL: ", cfg.API_BASE_URL)
  }
  return config
}, error => {
  // Message.error('请求错误: ' + error.message); // 替换为 Element UI 消息提示
  return Promise.reject(error);
});

// 响应拦截器
instance.interceptors.response.use(
  response => {
    const data = response.data;
    if (data && !data.Status) { // 判断 Status 是否为 false
      // Message.error(`Error: ${data.Message || 'Unknown error'}`); // 使用 Element UI 消息提示
      return data;;
    } else {
      return data; // 返回整个响应数据
    }
  },
  error => {
    if (error.response) {
      // 处理服务器返回的错误响应
      // Message.error(`Error code ${error.response.status}: ${error.response.statusText}`);
    } else {
      // 处理网络问题
      // Message.error('No response from server');
    }
    return Promise.reject(error);
  }
);

export default instance;

四、部署与使用说明

打包项目生成 dist 目录

修改 dist/config.json 中的 API_BASE_URL

刷新页面即可生效,无需重新打包

五、总结

通过引入运行时 config.json,将后端 IP 配置从构建期迁移到运行期,彻底解决了局域网多项目部署频繁改包的问题。

相关推荐
qq_283720051 天前
Cesium实战(三):加载天地图(影像图,注记图)避坑指南
json·gis·cesium
雷帝木木1 天前
Flutter for OpenHarmony:Flutter 三方库 cbor 构建 IoT 设备的极致压缩防窃协议(基于标准二进制 JSON 表达格式)
网络·物联网·flutter·http·json·harmonyos·鸿蒙
长安11081 天前
JsonCpp的编译与使用
json
凌晨一点的秃头猪1 天前
JSON 文件基础介绍
json
凌晨一点的秃头猪1 天前
Python JSON 模块核心函数超详细指南
json
小江的记录本1 天前
【JWT】JWT(JSON Web Token)结构化知识体系(完整版)
前端·网络·web安全·http·网络安全·json·安全架构
早點睡3901 天前
ReactNative项目OpenHarmony三方库集成实战:react-native-json-tree
react native·react.js·json
清水白石0082 天前
Python 对象序列化深度解析:pickle、JSON 与自定义协议的取舍之道
开发语言·python·json
晨欣2 天前
如何根据 config.json 核对 MoE 模型的激活参数:以 gpt-oss-120b 为例(GPT-5.4-high 生成)
gpt·大模型·json·openai
带刺的坐椅2 天前
Snack4 Json 流式解析与自动结构修复深度指南
java·llm·json·jsonpath