gpt4 book ai didi

Angular CLI : Proxy websocket with proxy. conf.json

转载 作者:太空狗 更新时间:2023-10-29 17:32:48 33 4
gpt4 key购买 nike

我正在尝试使用 Angular CLI 使用 ng serve --proxy-config proxy.conf.json 来代理 websockets,但由于出现此错误而无法正常工作:

与“ws://stream/connect”的 WebSocket 连接失败:连接建立时出错:net::ERR_NAME_NOT_RESOLVED

下面是我如何实例化 websocket 和我的代理配置:

// WebSocket instantiation
const ws = new WebSocket('ws://stream/connect');

// proxy.conf.json
"stream/**": {
"target": "wss://someurl.com:443",
"secure": false,
"ws": true
}

我错过了什么吗?这似乎是可行的,但我无法让它正常工作!

这个已关闭的问题 https://github.com/angular/angular-cli/issues/6081没有帮助这也没有stackoverflow answer .

最佳答案

我想通了!如果它可以帮助任何人...

默认情况下,Angular CLI 在端口 4200 上运行应用程序并且代理正在监听同一端口...因此我应该这样做:

// websocket instantiation
const ws = new WebSocket('ws://localhost:4200/stream/connect');

// proxy.conf.json
"/stream/*": {
"target": "https://someurl.com:443",
"secure": false,
"ws": true
}

WebSocket 构造函数中的硬编码 localhost:4200 不会在每个已部署的环境中工作,因为代理正在监听的 url 会有所不同......所以我来了动态获取位置主机和协议(protocol)并在 WebSocket 构造函数中使用它:

// set ws protocol when using http and wss when using https
const protocol = window.location.protocol.replace('http', 'ws');
// get location host
const host = window.location.host;
// websocket instantiation
const ws = new WebSocket(`${protocol}//${host}/stream/connect`);

然后 BAM ... 瞧! 🎊 🎉 👏

关于 Angular CLI : Proxy websocket with proxy. conf.json,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48793151/

33 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com