vue动态多环境配置websocket的ws://地址

本文讨论了在Vue项目中如何处理多环境配置,特别是WebSocket请求的问题。当使用nginx代理时,HTTP请求能正常工作,但WebSocket请求需要具体的IP和端口。解决方案是在不同环境中动态获取WebSocket URL,例如在开发环境使用.env配置,在生产环境通过window.document.location.host拼接。这确保了在不同环境下WebSocket连接的正确性。
摘要由CSDN通过智能技术生成

前景

一般vue多环境配置涉及三个文件:.env.development,.env.production,.env.test去配置,通过执行不同命令来区分运行环境。现在公司要求前端不要写死ip地址,防止部署的时候忘记更换命令部错包,通过nginx去代理配置不同端口。
现要求的配置文件

// .env.development是本地的开发环境正常写地址
VUE_APP_BASE_API = 'http://aaaa:8080'
VUE_APP_BASE_API_WEBSOCKET = 'ws://sss:8080'
//.env.production文件 /gateway是运维同学做的nginx代理,会指向我们想要的ip地址和端口
VUE_APP_BASE_API = '/gateway'
VUE_APP_BASE_API_WEBSOCKET = '/socket'

问题来了

通过上面的方式正常的http请求是可以正常访问的,但是websocket代理的地址不行,websocket请求必须要加上ip和端口才行(VUE_APP_BASE_API_WEBSOCKET = 'ws://xxxx:8080/socket’可以正常访问),但是不能写成“VUE_APP_BASE_API_WEBSOCKET = ‘ws://xxxx:8080/socket’”
必须要写活

websocket-api.js文件(websocket接口请求文件)
// 判断当前是什么环境, 如果是开发环境就用.env.development文件的配置,如果是生产环境就用拼接方式
// window.document.location.host当前窗口的 location 或 URL 的 hostname 和 port 号码
const env = process.env.NODE_ENV
const wsUrl = env === 'development' ? process.env.VUE_APP_BASE_API_WEBSOCKET : `ws://${window.document.location.host}/socket`
// 州数据大屏
export const cityData = (userId) => {
  return `${wsUrl}/getContinentStatistics/18`
}
  • 1
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值