新用户注册入口 老用户登录入口

[转载]websocket服务器无响应,WebSocket服务器因某些原因无法正常工作(WebSocket server not working for some reasons)...

文章作者:转载 更新时间:2023-03-19 12:00:21 阅读数量:51
文章标签:ws库连接问题控制台输出
本文摘要:文章讨论了在使用`ws`库创建WebSocket服务器时遇到的连接问题。作者指出,在运行本地WebSocket服务器并尝试通过浏览器访问`localhost:8080`时,控制台未输出预期的日志信息“client connected on localhost:8080”。为解决此问题,需明确WebSocket不能直接在浏览器地址栏中建立连接,而是需要通过HTML页面中的JavaScript代码来创建WebSocket客户端以连接到WebSocket服务器(如`var socket = new WebSocket('ws://localhost:8080')`)。同时,文章还提到了在服务器端使用RxJS Observable的fromEvent方法监听'connection'事件,以便在客户端成功连接时触发日志打印。
转载文章

本篇文章为转载内容。原文链接:https://blog.csdn.net/weixin_34862561/article/details/119512220。

该文由互联网用户投稿提供,文中观点代表作者本人意见,并不代表本站的立场。

作为信息平台,本站仅提供文章转载服务,并不拥有其所有权,也不对文章内容的真实性、准确性和合法性承担责任。

如发现本文存在侵权、违法、违规或事实不符的情况,请及时联系我们,我们将第一时间进行核实并删除相应内容。

WebSocket服务器因某些原因无法正常工作(WebSocket server not working for some reasons)

我尝试使用ws创建一个非常简单的服务器,当我运行服务器node index.js并且我在我的浏览器中午餐localhost:8080时,我的控制台中没有任何内容。

我应该看到client connected on localhost:8080打印到控制台

-index.js

const WebSocketServer = require('ws').Server;

const wss = new WebSocketServer({port: 8080});

const onConnect = wss => console.log('client connected on localhost:8080');

Rx.Observable

.fromEvent(wss, 'connection')

.subscribe(onConnect);

I tried to create a very simple server using ws, When i run the server node index.js and i lunch localhost:8080 in my browser nothing appear in my console.

i should see client connected on localhost:8080 printed to the console

-index.js

const WebSocketServer = require('ws').Server;

const wss = new WebSocketServer({port: 8080});

const onConnect = wss => console.log('client connected on localhost:8080');

Rx.Observable

.fromEvent(wss, 'connection')

.subscribe(onConnect);

原文:https://stackoverflow.com/questions/37480475

更新时间:2020-09-13 19:09

最满意答案

您无法通过直接在浏览器中打开它来连接到WebSocket。 您应该使用某个HTML页面创建HTTP服务器和响应。 在此HTML页面中,您应该包含连接到WebSocket服务器的javascript:

var socket = new WebSocket("ws://localhost:8080");

You can't connect to WebSocket by open it directly in a browser. You should create HTTP server and response with some HTML page. In this HTML page you should include javascript that connects to your WebSocket server:

var socket = new WebSocket("ws://localhost:8080");

相关问答

为了证明接收到握手,服务器必须获取两条信息并将它们组合以形成响应。 第一条信息来自| Sec-WebSocket-Key | 客户端握手中的头字段: Sec-WebSocket-Key: dGhlIHNhbXBsZSBub25jZQ==

具体而言,如上例所示,| Sec-WebSocket-Key | 标题字段的值为“dGhlIHNhbXBsZSBub25jZQ ==”,服务器 将串联字符串“258EAFA5-E914-47DA-95CA-C5AB0DC85B11” 形成字符串“dGhl

...

我找到了解决方法。 我已经修改了我的wsgi.py,现在它可以工作: import os

os.environ.setdefault("DJANGO_SETTINGS_MODULE", "myapp.settings")

# This application object is used by any WSGI server configured to use this

# file. This includes Django's development server, if the WSGI

...

好吧,就我而言, RewriteBase /元素解决了这个问题。 如果有人因为shauninmann视网膜代码而遇到这个问题,我就把它留在那里。

Options -MultiViews

RewriteEngine on

RewriteBase /

RewriteCond %{HTTP_COOKIE} HTTP_IS_RETINA [NC]

RewriteCond %{REQUEST_FILENAME} !@2x

RewriteRule ^(.*)\

...

如果您的服务器正在侦听端口80上的连接,它是否在谈论http? 因为如果没有,不要在端口80上侦听:端口80已经建立为携带http流量。 下一步 - ipaddress和端口一起是端点的唯一标识符。 如果远程客户端通过端口80连接到您的服务器,而不是目标IP和端口,则没有其他信息表明网络层必须识别哪个应用程序(在端口80上侦听)应该获得该数据包。 鉴于配置多个IP地址非常困难 - 在NAT上是不可能的 - 将数据包路由到正确的侦听器的唯一信息就是端口。 所以你不能让两个应用程序在同一个端口上侦听。

...

您无法通过直接在浏览器中打开它来连接到WebSocket。 您应该使用某个HTML页面创建HTTP服务器和响应。 在此HTML页面中,您应该包含连接到WebSocket服务器的javascript:

var socket = new WebSocket("ws://localhost:8080");

You can't connect to WebSocket by open it directly in a browser. You should crea

...

所以我通过握手解决了我的特殊问题,而且非常无聊。 我需要两套“\ r \ n”才能完成握手。 所以为了解决我上面描述的握手问题(Javascript WebSocket没有进入OPEN状态)我需要对我的服务器端PHP进行以下更改(注意最后的\ r \ n \ r \ n,doh) : function dohandshake($user,$buffer){

// getheaders and calcKey are confirmed working, can provide source

...

是。 独立的WebSocket服务器通常可以在任何端口上运行。 浏览器客户端打开与非HTTP(S)端口上的服务器的WebSocket连接没有问题。 默认端口为80/443的主要原因是它们是最可靠的大规模使用端口,因为它们能够遍历阻止所有其他端口上所有流量的许多企业防火墙。 如果这对您的受众来说不是问题(或者您有基于HTTP的回退),那么为WebSocket服务器使用备用端口是完全合理的(并且更容易)。 另一种选择是使用80/443端口,但使用单独的IP地址/主机名。 Yes. A standalo

...

Tyrus抱怨Connection: keep-alive, Upgrade header。 Firefox在这里没有做错任何事。 关于如何处理Connection标头,Tyrus过于严格,没有遵循WebSocket规范( RFC-6455 )。 RFC 4.1中的RFC规定: 6. The request MUST contain a |Connection| header field whose value

MUST include the "Upgrade" tok

...

说实话,我不能100%确定地说这是什么,但我有一个非常强烈的怀疑。 我的代码中包含了太多的命名空间,我相信在编译器等实际运行时会出现一些混乱。 显然,Microsoft.Web.Websockets和SignalR的命名空间都包含WebSocketHandler。 虽然我不知道SignalR的所有细节,但看起来THAT命名空间中的WebSocketHandler并不意味着在SignalR之外使用。 我相信这个类正在被引用,而不是Microsoft.Web.Websockets中的那个,因为它现在起

...

您应该使用websocket处理程序,而不是请求处理程序,尝试使用此示例 You should use the websocket handler, not the request handler, try with this example

本篇文章为转载内容。原文链接:https://blog.csdn.net/weixin_34862561/article/details/119512220。

该文由互联网用户投稿提供,文中观点代表作者本人意见,并不代表本站的立场。

作为信息平台,本站仅提供文章转载服务,并不拥有其所有权,也不对文章内容的真实性、准确性和合法性承担责任。

如发现本文存在侵权、违法、违规或事实不符的情况,请及时联系我们,我们将第一时间进行核实并删除相应内容。

相关阅读
文章标题:[转载][洛谷P1082]同余方程

更新时间:2023-02-18
[转载][洛谷P1082]同余方程
文章标题:[转载]webpack优化之HappyPack实战

更新时间:2023-08-07
[转载]webpack优化之HappyPack实战
文章标题:[转载]oracle 同时更新多表,在Oracle数据库中同时更新两张表的简单方法

更新时间:2023-09-10
[转载]oracle 同时更新多表,在Oracle数据库中同时更新两张表的简单方法
文章标题:[转载][Unity] 包括场景互动与射击要素的俯视角闯关游戏Demo

更新时间:2024-03-11
[转载][Unity] 包括场景互动与射击要素的俯视角闯关游戏Demo
文章标题:[转载]程序员也分三六九等?等级差异,一个看不起一个!

更新时间:2024-05-10
[转载]程序员也分三六九等?等级差异,一个看不起一个!
文章标题:[转载]海贼王 动漫 全集目录 分章节 精彩打斗剧集

更新时间:2024-01-12
[转载]海贼王 动漫 全集目录 分章节 精彩打斗剧集
名词解释
作为当前文章的名词解释,仅对当前文章有效。
WebSocketWebSocket是一种在单个TCP连接上进行全双工通信的协议,允许客户端和服务器之间建立持久的、双向的数据传输通道。在文中提到的场景中,作者使用ws库在Node.js中创建了一个WebSocket服务器,并尝试通过浏览器与之建立连接,以实现实时数据通信。
WebSocket服务器WebSocket服务器是一种遵循WebSocket协议的应用程序,能够接收来自客户端的WebSocket连接请求,并维持这些连接以实现双向实时通信。在文章中,作者构建了一个运行在localhost:8080端口上的WebSocket服务器,但由于未正确配置客户端连接,导致控制台未能输出预期的连接成功信息。
RxJS ObservableRxJS Observable(可观察对象)是Reactive Extensions for JavaScript (RxJS)库中的核心概念,它代表了可发出多个值的异步数据流。在该文的JavaScript代码片段中,作者使用Rx.Observable.fromEvent方法将WebSocket服务器实例上的'connection'事件转换为可观察对象,然后订阅这个可观察对象以便在客户端连接到WebSocket服务器时触发相应的事件处理函数(即onConnect函数),从而在控制台上打印出连接成功的日志消息。
延伸阅读
作为当前文章的延伸阅读,仅对当前文章有效。
在了解了WebSocket服务器的工作原理及其在Node.js中使用ws库遇到的问题后,进一步深入探讨WebSocket技术的最新应用与发展显得尤为重要。近期,随着Web实时通信需求的增长,WebSocket协议的应用场景愈发广泛,如在线协作工具、实时交易系统、游戏开发、物联网设备数据同步等领域。
2021年,Mozilla发布了一篇关于WebSocket性能优化的文章,其中详细介绍了如何针对现代浏览器进行WebSocket连接的性能调优,包括握手过程、数据帧压缩以及多路复用等高级特性。同时,随着HTTP/3的推进,WebSocket在QUIC协议上的实验性支持也在逐步展开,未来有望实现更快速、更稳定的长连接通信。
另外,各大云服务商如AWS、阿里云等也纷纷推出了对WebSocket服务的支持,通过Serverless架构和WebSocket API,开发者可以更加便捷地构建基于WebSocket的应用程序,并能有效解决WebSocket服务器的运维与扩展问题。
此外,对于安全性方面,最新的WebSocket安全实践指南强调了加密传输、防篡改机制以及权限验证等方面的重要性,确保在提供实时通信能力的同时,保障用户数据的安全。
总之,在WebSocket技术不断发展的今天,掌握其原理并关注相关领域的前沿动态,将有助于开发者更好地应对实际项目中的挑战,提升用户体验和系统性能。
知识学习
实践的时候请根据实际情况谨慎操作。
随机学习一条linux命令:
sudo !! - 以管理员权限重新执行上一条命令。
随便看看
拉到页底了吧,随便看看还有哪些文章你可能感兴趣。
纯js实用T恤衫花纹图案预览特效 01-26 基于Bootstrap仿Github样式下拉列表框插件 08-08 jQuery电子邮件地址填写自动完成插件 04-30 Superset 数据源连接配置:精细化自定义SQLAlchemy URI实现数据分析与可视化,含SSL加密连接实例 03-19 jquery可任意拖动排序的导航图片效果 02-23 侧边栏个人图文简历HTML模板 12-09 Beego框架升级中的Bee工具版本兼容性问题与迁移策略:结构变更、功能接口变动及社区解决方案 12-07 Kibana无法启动:针对服务器内部错误的Elasticsearch连接、配置文件、端口冲突与资源排查解决(注:由于字数限制,未能完全包含所有关键词,但包含了核心问题描述及几个关键排查点) 11-01 ClickHouse外部表使用中文件权限与不存在问题的解决方案:错误提示、查询操作与文件路径管理实务 09-29 本次刷新还10个文章未展示,点击 更多查看。
Apache Atlas UI无法正常加载与样式丢失问题排查及解决方案:关注网络连接、浏览器缓存与开发者工具应用 09-25 Greenplum数据库中数据插入操作详解:单行多行插入与gpfdist实现大批量导入 08-02 [转载]html5 footer header,html-5 --html5教程article、footer、header、nav、section使用 07-16 [转载][GCC for C]编译选项---IDE掩盖下的天空 06-29 简洁大方珠宝钻石收藏网站模板下载 06-20 黑色高端精致汽车4s店美容html5模板下载 06-01 蓝色互联网项目融资管理平台网站模板 05-16 响应式游戏开发类企业前端cms模板下载 05-02 Beego框架动态路由实现:重定向与命令行参数驱动的路由设计实践 04-05 .NET 中字典操作避免 KeyNotFoundException:TryGetValue、ContainsKey 与 GetOrAdd 实践详解 04-04 [转载]2021/4/23爬虫第五次课(爬虫网络请求模块下下) 03-01
时光飞逝
"流光容易把人抛,红了樱桃,绿了芭蕉。"