- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我应该在非 80 端口上使用 WebSocket 吗?它会破坏使用现有 Web/HTTP 基础设施的全部目的吗?而且我认为它不再适合非 80 端口上的 WebSocket 这个名称。
如果我在其他端口上使用 WebSocket,为什么不直接使用 TCP?或者WebSocket协议(protocol)本身有什么特殊的好处吗?
由于当前的 WebSocket 握手采用 HTTP UPGRADE 请求的形式,这是否意味着我必须在端口上启用 HTTP 协议(protocol)才能完成 WebSocket 握手?
最佳答案
Shall I use WebSocket on non-80 ports? Does it ruin the whole purpose of using existing web/HTTP infrastructures? And I think it no longer fits the name WebSocket on non-80 ports.
您可以在主机操作系统允许并且允许您的客户端连接的任何端口上运行 webSocket 服务器。
但是,在端口 80(或 443)上运行它有许多优点。
网络基础设施通常已部署并在端口 80 上打开,用于从客户端所在位置(例如台式计算机、移动设备等)到服务器所在位置(例如数据中心)的出站连接。因此,在端口 80 上部署 webSocket 应用程序通常不需要防火墙或路由器配置等中的新漏洞。可能需要更改配置才能在不同端口上运行。例如,许多大型企业网络对于可在哪些端口上建立出站连接非常挑剔,并且仅针对某些标准和预期行为进行配置。某些公司网络可能不允许为 webSocket 连接选择非标准端口。这是使用端口 80 的重要原因(已锁定配置的专用网络的最大互操作性)。
许多从浏览器运行的 webSocket 应用程序希望利用主机网页端口 80 上已使用的现有安全/登录/身份验证基础设施。如果所有内容都位于同一端口上,则使用完全相同的基础设施来检查 webSocket 连接的身份验证可能会更简单。
一些 webSocket 的服务器基础设施(例如 node.js 中的 socket.io)使用组合服务器基础设施(单个进程,一个监听器)来支持 HTTP 请求和 webSocket。如果两者都在同一端口上,这会更简单。
If I use WebSocket over other ports, why not just use TCP directly? Or is there any special benefits in the WebSocket protocol itself?
webSocket 协议(protocol)最初被定义为从浏览器到服务器工作。浏览器没有通用的 TCP 访问,因此如果您想要一个没有自定义浏览器插件的持久套接字,那么可以使用 webSocket。与普通 TCP 连接相比,webSocket 协议(protocol)提供了利用 HTTP 身份验证和 cookie 的能力,这是执行应用程序级和端到端保持事件 ping/pong 的标准方法(TCP 提供跳级保持事件) ,但不是端到端),内置的成帧协议(protocol)(您必须在 TCP 中设计自己的数据包格式)以及许多支持这些更高级别功能的库。基本上,webSocket 的工作级别比 TCP 更高(在幕后使用 TCP),并提供更多大多数人认为有用的内置功能。例如,如果使用 TCP,您要做的第一件事就是获取或设计一个协议(protocol)(一种表达数据的方式)。这已经内置于 webSocket 中。
And since current WebSocket handshake is in the form of a HTTP UPGRADE request, does it mean I have to enable HTTP protocol on the port so that WebSocket handshake can be accomplished?
您必须在要使用 webSocket 的端口上运行一个 HTTP 服务器,因为所有 webSocket 请求都以 HTTP 请求开始。它不必是功能强大的 HTTP 服务器,但它必须处理初始 HTTP 请求。
关于websocket - 我应该在 80 以外的端口上使用 WebSocket 吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28522857/
假设浏览器被强制终止,并且没有关闭消息发送到 Tornado 服务器。 Tornado 怎么知道(或者它甚至知道?)这个连接已经在客户端终止了?翻看Tornado websocket code这对我来
我目前正在开发一款使用 WebSockets 的基于浏览器的多人游戏。我的首要任务是低延迟以及与各种平台和网络设置的兼容性。 但是我正在做密码验证。我还有聊天功能,我认为玩家的隐私很重要。因此,我认为
我必须设计一个解决方案,允许通过远程托管的网络应用程序读取本地传感器生成的实时数据。 设计仍在进行中:传感器的数据可以由安装在客户端计算机上的 Windows 应用程序/服务处理,或者由位于客户端计算
WebSocket的端口是什么? WebSocket 使用什么协议(protocol)? 当防火墙阻止除 80 和 443 端口之外的所有端口时,WebSocket 是否工作? 最佳答案 What i
有一个 fantastic answer其中详细介绍了 REST apis 的工作原理。 websockets 如何以类似的细节工作? 最佳答案 Websocket 创建并代表了服务器和客户端之间双向
请原谅我的无知,因为我在负载均衡器和 websockets 方面的经验有限。我试图了解客户端如何通过 websockets 连接到位于负载均衡器后面的服务器集群。 我对负载均衡器的理解是它们就像反向代
我正在尝试使用 websocket 发送音频消息,我应该将音频流更改为什么类型的消息,以便我可以使用套接字发送? 如果我直接使用 websocket.send(audio),我会得到一个错误“DOME
我对 WebSockets 的前景感到非常兴奋。由于我在过去构建了一些基于桌面套接字的游戏和 Web 游戏,因此我热衷于将这两种方法结合起来构建基于 Web 的多人游戏,而无需长时间轮询。 自从 Fi
我读过很多关于实时推送通知的文章。并且简历是 websocket 通常是首选技术,只要您不关心 100% 的浏览器兼容性。然而,one article指出 Long polling - potenti
我很难找到文档或教程,以便通过网络套接字发送文件。 这是我的JS: ['dragleave', 'drop'].forEach(event_name => document.addEventListe
我正在使用 Dart 的 WebSocket 类(dart:io 和 dart:html 版本)连接到 Dart WebSocket 服务器。当我让客户端使用自定义关闭代码和原因关闭 Web 套接字连
谷歌浏览器框架是否支持 websocket? 最佳答案 答案是肯定的,Chrome Frame supports websockets .我不确定,但这也可能取决于您安装的 Chrome 版本。我有
是否可以在同一应用程序(同一端口)中托管一个普通 Bottle 应用程序和一个 WebSocket 应用程序(例如: https://github.com/defnull/bottle/blob/ma
我有一个支持网络套接字的服务器。浏览器连接到我的网站,每个浏览器都会打开一个到 www.mydomain.example 的 Web 套接字。这样,我的社交网络应用程序就可以向客户端推送消息。 传统上
我是 Websockets 新手。在阅读有关 websockets 的内容时,我无法找到一些疑问的答案。我希望有人能澄清一下。 websocket 是否仅将数据广播到所有连接的客户端而不是发送到特定客
客户端可以通过 websockets 连接到服务器多长时间?是否有时间限制,它们是否有可能连在一起多年? 最佳答案 理论上,WebSocket 连接可以永远持续下去。假设端点保持正常运行,长期存在的
我正在尝试使用 websockets 制作自己的聊天客户端,并认为我会从 Tomcat 7 websocket chat example code. 开始。 .我已经成功编译并部署了ChatAnnot
我有一个使用 AdSense 的应用程序,据我所知,由于 AdSense 政策,不允许进行轮询。我想知道如果我使用 WebSockets 并且服务器在创建新数据时向客户端发送新数据并且在客户端上显示新
在 servlet 世界中,我会使用 cookie 和 HttpSession 之类的东西来识别谁在访问我的 Restful 服务以将请求路由到正确的数据。将 Sec-WebSocket-Key 用作
我必须使用 websocket 实现一个聊天应用程序,用户将通过群组聊天,可以有数千个群组,并且一个用户可以在多个群组中。我正在考虑两种解决方案: [1] 对于每个群聊,我创建一个 websocket
我是一名优秀的程序员,十分优秀!