项目中用运行时 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 配置从构建期迁移到运行期,彻底解决了局域网多项目部署频繁改包的问题。

相关推荐
Rooting++18 小时前
package.json三种依赖的区别
vue.js·json
曹牧1 天前
C#:DataGridView控件中展示JSON内容
开发语言·c#·json
howard20052 天前
4.4 Spark SQL数据源 - JSON
json·spark sql数据源
灰子学技术2 天前
Envoy gRPC-JSON 转码器功能实现分析
json
夜雪闻竹2 天前
Cursor 的 state.vscdb 解析踩坑记
json·aigc·ai编程
水煮白菜王2 天前
JSONEditor 使用指南
前端·javascript·chrome·json
会编程的土豆3 天前
Gin 中 `c.BindJSON` 与 `c.JSON` 详细讲解
c语言·json·gin
ID_180079054734 天前
企业级实战:淘宝商品详情 API简要说明,json数据返回参考
json
学习3人组4 天前
业务主表+JSON自定义字段
java·spring boot·json
Car124 天前
在vscode中添加一个tasks.json实现 rt thread的scons编译功能
vscode·json·build·scons