nodejs搭建websocket(前后端交互小demo)

效果:

在这里插入图片描述

服务端代码:
var ws = require("nodejs-websocket");

ws.createServer(function(conn){
  conn.on("text",function(str){
      //服务端接收到的数据
      console.log("服务端收到:" + str);
      //接收到的数据再发送回客户端
      conn.sendText("服务端发回-来自前端的"+str);
      let input = {
        code:200,
        parkingName:'GGGGGGG测试库',
        plateNUmber:"贵A55555"
      }
      setTimeout(()=>{
        input = JSON.stringify(input)
        conn.send(input,function(){
          console.log('如果说后端想要监听发送状况,能走进来是否意味着发送成功')
        });
        console.log(conn.readyState)   //ws状态
      },2000)
  });


  conn.on("close",function(code,reason) {
      console.log("服务端监听到关闭连接.");
  });

  conn.on("error",function(code,reason) {
      console.log("服务端监听到连接失败.")
  });

  conn.on("pong",function(res){
    console.log(res)
  })
}).listen(8848);

客户端代码:
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <title>ws demo</title>
</head>

<body>

    <div id="mess">正在连接...</div>
    <div>
        <button id="state1" >发送</button>
        <a> 已发送:</a>
        <a id="sendnews"></a><br>
        <a>已接收:</a>
        <a id="receivenews"></a>
    </div>

    <script>
        var mess = document.getElementById("mess");
        if(window.WebSocket){
            var ws = new WebSocket('ws://127.0.0.1:8848');

            ws.onopen = function(e){
                console.log("连接服务器成功");
                mess.innerHTML = "连接成功"
                ws.send("连接成功",function(e){
                  console.log('这里偶吗')
                });
            }

            ws.onclose = function(e){
                console.log("服务器关闭");
                mess.innerHTML = "服务器关闭"
            }

            ws.onerror = function(){
                console.log("连接出错");
                mess.innerHTML = "连接出错"
            }

            //收到服务器数据后的回调函数
            ws.onmessage = function(e){
                document.getElementById("receivenews").innerHTML=e.data;
            }

            //设置点击事件
            document.getElementById("state1").onclick = function(e){
                console.log('之前',ws.readyState)   //这个是websocket的状态
                console.log('之前',ws.bufferedAmount)   //这个是数据发送的状态
                ws.send("客户端发送的呵呵哈哈哈");
                console.log('发送之后',ws.bufferedAmount)   //这个是数据发送的状态
                document.getElementById("sendnews").innerHTML="客户端发送的呵呵哈哈哈"
            }
        }
    </script>
</body>

</html>

心跳机制:

这里我并没有写心跳机制以及重连机制。

websocket
心跳机制是哪一端做的 怎么做到定时发送的
心跳是客户端与服务端约定的,客户端发送特定东西,服务端接收识别回应指定的东西,就形成了我“Ping”你“Pong”的效果。
另外服务端在send之后的回调,能走进回调是否就意味着send成功.

但是我发现,ws有个状态。无论是客户端还是服务端都有。是可以描述两端连接状态的。
那么两端各自在连接成功之后写一个定时任务,不停地去判断这个状态是不是也可以变相的达到心跳的目的,因为初衷都是判断当前连接状态如何。

 //每次send或其他的监听函数之后可以去看这个状态
 console.log(ws.readyState)   //这个是websocket的状态

在这里插入图片描述

  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
### 回答1: 好的,我可以帮你回答关于 Node.js 配置 WebSocket 服务器的问题。 首先,要配置 WebSocket 服务器,你需要使用 Node.js 的 `ws` 模块,它可以让你轻松地创建和管理 WebSocket 连接。 以下是一个简单的例子,展示了如何使用 `ws` 模块创建一个 WebSocket 服务器: ```javascript const WebSocket = require('ws'); const server = new WebSocket.Server({ port: 8080 }); server.on('connection', (socket) => { console.log('New connection established'); socket.on('message', (message) => { console.log(`Received message: ${message}`); }); socket.on('close', () => { console.log('Connection closed'); }); }); ``` 在上面的例子中,我们首先引入了 `ws` 模块,然后创建了一个 WebSocket 服务器,监听 8080 端口。当有新的 WebSocket 连接建立时,会触发 `connection` 事件。在 `connection` 事件处理程序中,我们监听了 `message` 事件和 `close` 事件,分别处理收到的消息和连接关闭的情况。 当有消息发送到 WebSocket 服务器时,`message` 事件将被触发,它的处理程序将打印收到的消息。当连接关闭时,`close` 事件将被触发,它的处理程序将打印连接已关闭的消息。 这是一个非常简单的例子,可以让你开始构建 WebSocket 服务器。当然,在实际应用中,你需要更多的逻辑来处理不同的消息类型和连接管理等问题。但是,通过这个例子,你可以了解如何使用 `ws` 模块来创建 WebSocket 服务器,并开始构建自己的应用程序。 ### 回答2: Node.js是一个基于Chrome V8引擎的JavaScript运行环境,它的出现使得我们可以使用JavaScript语言编写服务器端代码,而不再局限于浏览器环境。Websocket是HTML5中新增的协议,可以在浏览器和服务器之间建立双向通信的连接,它与HTTP/HTTPS协议不同,不需要请求和响应,可以实现实时的数据传输和实时交互。在Node.js中,我们可以使用第三方库socket.io来搭建Websocket服务器。 下面是使用Node.js和socket.io搭建Websocket服务器的步骤: 1.安装Node.js和socket.io库。可以从Node.js官网下载Node.js,然后通过npm命令安装socket.io。在命令行中输入以下命令: $ npm install socket.io 2.编写服务端代码。在Node.js中,我们可以使用http模块来创建服务器,然后使用socket.io模块来处理Websocket连接。下面是一个简单的代码示例: var http = require('http'); var app = http.createServer(function(req, res) { //处理其他HTTP请求 }); var io = require('socket.io')(app); io.on('connection', function(socket){ //处理Websocket连接 }); app.listen(3000); //监听端口号3000 在上面的代码中,我们使用http.createServer()方法创建一个Node.js服务器,并监听http请求。然后,我们将创建的服务器传递给socket.io()方法创建Websocket服务器并监听Websocket连接事件。在连接事件中,我们可以处理客户端和服务器之间的消息传输和数据交互。 3.编写客户端代码。在浏览器中,我们可以使用socket.io的客户端库来建立Websocket连接并进行数据交互。在HTML页面中引入socket.io客户端库: <script src="//cdn.socket.io/socket.io-1.4.5.js"></script> 然后,在JavaScript中创建一个Socket对象: var socket = io.connect('http://localhost:3000'); 在Socket对象上,我们可以监听服务器发送过来的事件,并在事件发生时进行相应的处理。例如,我们可以监听服务器发送的消息: socket.on('message', function(data) { console.log(data); }); 4.运行Websocket服务器。在命令行中输入以下命令: $ node app.js 其中app.js是你的服务端代码文件。 至此,一个基于Node.js和socket.io的Websocket服务器就搭建完成了。通过WebSocket,我们可以在客户端和服务器之间实时交互数据,从而实现更加实时的应用程序。 ### 回答3: Nodejs是一款非常流行的JavaScript服务器端编程语言。使用Nodejs构建Websocket服务是非常容易的。Websocket是一种双向通信协议,可以在客户端和服务器端建立持续连接。Websocket协议是HTTP协议升级版,因此可以很容易地与现有的Web应用程序集成。 为了搭建Websocket服务器,首先需要安装Nodejs。安装Nodejs可以通过官方网站或各种包管理器进行。安装完成后,通过命令行,可以创建一个Nodejs项目。在项目中,可以使用NPM(Nodejs的包管理器)安装WebSocket模块。 WebSocket模块提供了一些类和方法,可以轻松地创建WebSocket服务器和客户端。在服务器端,可以使用WebSocket.Server类来创建一个WebSocket服务器实例,监听指定端口。一旦连接建立,就可以使用WebSocket对象来发送和接收消息。 下面是一个简单的Nodejs程序,用于创建Websocket服务器: ``` const WebSocket = require('ws'); const wss = new WebSocket.Server({ port: 8080 }); wss.on('connection', function connection(ws) { console.log('A new client just connected!'); ws.on('message', function incoming(message) { console.log('Received message:', message); // Echo the received message back to the client ws.send(message); }); }); ``` 通过Nodejs的require函数引入WebSocket模块。在以上例子中,创建了一个WebSocket.Server实例,绑定在8080端口。当客户端连接到服务器时,会调用connection事件回调函数。在此回调函数中,对接收到的消息进行处理,并将其发送回客户端。 这是一个非常简单的例子,但是它展示了如何创建一个Websocket服务器,以及如何处理连接和消息。您可以扩展此示例,添加更多的功能,例如广播消息等。 总体而言,使用Nodejs构建Websocket服务器是一件非常简单的事情。只需安装Nodejs并使用WebSocket模块即可开始构建WebSocket服务器。随着WebSocket的不断发展和流行,使用Nodejs构建WebSocket服务器将变得更加广泛和受欢迎。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

_小郑有点困了

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值