nodejs建立长连接模块socket.io

nodejs建立长连接模块socket.io

长连接

服务器端发送完新数据也不断开连接,继续等待下一份新数据,除非超过了一定时限(即自定义的最大连接空闲时长,浏览器可以超时重连)

WebSocket
什么是websocket?

用于建立客户端和服务端的双向交互通信,打开一条会话通道,让双方可以进行实时通信

这个链接的每一端就被称为socket,避免了使用传统的轮询方式来实现通信

websocket和socket.io之间的区别是什么?

socket.io是一个开源库,他是对websocket进行的封装

增强了浏览器的兼容性

使用起来更方便,功能也更强大

引入依赖包

npm i express -Snpm i socket.io -S

可以依照socket.io官方文档要求添加
服务器talkServer.js
const express = require('express');
const app = express();

//socket.io官方文档要求添加
const server = require('http').createServer(app);
const io = require('socket.io')(server);
//记录一下有几个人连接上了服务器
var userId = 0;
//监听connection事件,只要有客户端连接就执行回调函数
io.on('connection',(socket)=>{
    var user = ++userId;//当前连接到的用户的编号
    //socket就是连接到服务器的那个客户端
    //接收客户端消息
    //监听客户端的一个事件,事件名称自己定义
    socket.on('msg-from-client',function(data){
        io.emit('msg-from-server',user+"------>"+data)
    })
    //向客户端分发消息  
    io.emit('msg-from-server',user+'------上线了')
})
//socket.io官方文档要求开启端口监听使用server
server.listen(7777);
客户端webServer.js
const express = require('express');
const app = express();

//开启静态资源服务器
app.use(express.static('./public'));

app.listen('8888')
webServer.js中的静态文件talk.html
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        *{
            margin: 0;
            padding: 0;
        }
        .box{
            width: 400px;
            height: 550px;
            margin:50px auto;
            border:1px solid #ccc;
            position: relative;
        }
        .top{
            position: absolute;
            top:20px;
            left:20px;
            right:20px;
            bottom:80px;
            overflow: auto;
        }
        .bottom{
            position: absolute;
            bottom:20px;
            left:20px;
            right:20px;
        }
        #message{
            width: 300px;
            height: 30px;
            border:1px solid #ccc;
            line-height: 30px;
            float: left;
            padding-left:10px;
            box-sizing: border-box;
        }
        #send{
            width: 50px;
            float:right;
            height: 30px;
        }
        .row{
            line-height: 35px;
        }
    </style>
</head>
<body>
    <div class="box">
        <div class="top">
            
        </div>
        <div class="bottom" style="color: red;font-size: 200px;">
            <input type="text" id="message">
            <input type="button" value="发送" id="send">
        </div>
    </div>
    <script src="/jquery-1.12.4.js"></script>
    <!-- 
        我们下载的socket.io这个包里面有一个文件夹叫做socket.io-client,里面的dist/socket.io.js 
        把这个文件拷贝到前端静态资源服务器里面
    -->
    <script src="/socket.io.js"></script>
    <script>
        //引入socket.io.js以后就会有一个io方法,通过io连接服务端
        var socket = io('http://请求连接的服务端域名地址:7777');
        //记录下一共有多少条消息
        var count = 0;
        //监听服务器发送给客户端消息的事件
        socket.on('msg-from-server',function(data){
            count++;
            //把接收到的服务器消息,显示在聊天框里面
            $('.top').append('<div class="row">'+data+'</div>');
            $('.top').scrollTop(count*35);
        })

        //点击send给服务端发消息
        $('#send').click(function(){
            socket.emit('msg-from-client',$('#message').val());
            $('#message').val('')
        })
        //在message里面按回车也可以发消息
        $('#message').keyup(function(e){
            if(e.keyCode==13){
                socket.emit('msg-from-client',$('#message').val());
              $('#message').val('')
            }
        })
    </script>
</body>
</html>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一个使用Socket.IONode.js中实现通讯的示例代码: 1. 安装Socket.IO模块: ```shell npm install socket.io ``` 2. 创建服务器端(server.js): ```javascript var express = require('express'); var app = express(); var server = require('http').createServer(app); var io = require('socket.io')(server); // 监听客户端连接事件 io.on('connection', function(socket){ console.log('A client connected.'); // 监听客户端发送的消息事件 socket.on('message', function(data){ console.log('Received message from client:', data); // 触发事件告知客户端 io.emit('message', 'Server received your message: ' + data); }); // 监听客户端离开事件 socket.on('disconnect', function(){ console.log('A client disconnected.'); // 触发事件告知服务端 io.emit('disconnect', 'A client disconnected.'); }); }); // 启动服务器 server.listen(3000, function(){ console.log('Server is running on port 3000.'); }); ``` 3. 创建客户端(client.html): ```html <!DOCTYPE html> <html> <head> <title>Socket.IO Client</title> <script src="https://cdn.socket.io/socket.io-3.1.3.min.js"></script> <script> var socket = io(); // 发送消息给服务端 socket.emit('message', 'Hello, server!'); // 监听服务端发送的消息事件 socket.on('message', function(data){ console.log('Received message from server:', data); }); // 监听服务端触发的离开事件 socket.on('disconnect', function(data){ console.log('Server:', data); }); </script> </head> <body> <h1>Socket.IO Client</h1> </body> </html> ``` 请注意,以上代码仅为示例,实际使用时可能需要根据具体需求进行修改。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值