猿问

获取使用关闭代码1006关闭websocket的原因

我想知道websockets关闭的原因,所以我可以向用户显示正确的消息。


我有


sok.onerror=function (evt) 

     {//since there is an error, sockets will close so...

       sok.onclose=function(e){

           console.log("WebSocket Error: " , e);}

代码始终为1006,原因始终为“”。但是我想分开说出不同的结案原因。


例如,命令行给出了一个错误原因:“您不能删除它,因为数据库不允许您这样做”。但是在Chrome的控制台上,原因仍然是“”。


还有其他方法可以区分不同的结算原因吗?


HUX布斯
浏览 16258回答 3
3回答

波斯汪

就我而言,可能是@BIOHAZARD nginx proxy timeout。默认情况60下,套接字无活动的时间是秒我将其更改为24h nginx并解决了问题proxy_read_timeout 86400s;proxy_send_timeout 86400s;

慕桂英546537

当Chrome浏览器不符合WebSocket标准时,情况就是这样。当服务器启动关闭并向客户端发送关闭帧时,Chrome认为这是错误,并使用代码1006并没有原因消息将其报告给JS端。在我的测试中,Chrome从未响应服务器启动的关闭帧(关闭代码1000),表明代码1006可能表示Chrome正在报告自己的内部错误。PS Firefox v57.00可以正确处理此情况,并成功将服务器的原因消息传递给JS端。
随时随地看视频慕课网APP

相关分类

JavaScript
我要回答