socket.io的基本使用
服务端:
1.监听客户端连接:
io.on("connection",socket=>{ });
不分组数据传输:传输对象为当前socket
2.1给该socket所有客户端广播消息
socket.emit("名称",内容);
2.2给该socket除了自己外的所有客户端广播消息
socket.broadcast.emit("名称",内容);
2.3给该socket所有客户端广播消息
socket.emit("名称",内容);
2.4给在game房间内除了自己的其他所有客户端广播消息
socket.broadcast.to(‘game’).emit("名称",内容);
2.5给在game房间内包括自己的所有客户端广播消息
io.sockets.in(‘game’).emit("名称",内容);
3.监听该socket的客户端发送给服务端的消息
socket.on("名称",msg=>{ });
分组数据传输:生成命名空间来管理用户
服务端:
io.sockets.on('connection', function (socket) {
socket.on('firefox', function (data) {
socket.join('firefox');
});
socket.on('chrome',function(data){
socket.join('chrome');
});
});
//emit to 'room' except this socket client
socket.broadcast.to('chrome').emit('event_name', data);
//emit to all socket client in the room
io.sockets.in('chrome').emit('event_name', data)
客户端:
socket.emit('firefox'); //就可以加入 firefox 聊天室
socket.emit('chrome'); //就可以加入 chrome 聊天室
socket连接需要添加权限验证,让已登录用户socket直接连接到服务器上,未登陆的用户无条件拒绝连接
callback
函数有两个参数,第一个为 error
,第二个参数为是否授权bool值,通过授权回调函数应为 callback(null,true)
,其它情况下都为拒绝建立连接。
io.sockets.authorization(function (handshakeData, callback) {
callback(null, true);
}).
websocket是持久化的协议,http是非持久化的协议。
http的1.0协议中一个http连接只有一次request和response;
http的1.1协议中允许一个http连接,存在多次请求和接收数据。
websocket连线过程中,浏览器和服务器只需要做一个握手的动作就形成了一条快速通道,实现两者相互推送数据。
Socket.IO是一个WebSocket库,包括了客户端的js和服务器端的nodejs,它的目标是构建可以在不同浏览器和移动设备上使用的实时应用。
在客户端的话,可以通过<script src="/socket.io/socket.io.js"></script>
或引用socket.io的CDN服务。 <scriptsrc="http://cdn.socket.io/stable/socket.io.js"></script>
socket.io实现监听:
1.引用socket.io模块,调用listen方法传入端口号即可;
var app = require('express')();
var http = require('http').Server(app);
var io = require('socket.io')(http);
socket.io实现事件注册:
服务端:connection、disconnect、emit
客户端:connect、connecting、disconnect、connect_failed、reconnect、emit
io.on(connection,function(socket){
//连接成功
console.log("socket连接成功")
//断开连接
socket.on('disconnect',function(){
console.log("socket连接断开")
})
})
socket.io提供两种服务端广播方式。参数一:名称;参数二:内容
1.全局广播:socket.broadcast.emit('DATA',data);
2.命名空间广播:socket.broadcast.to('chat').emit('DATA',data)
1.创建对象:var ws = new WebSocket(url,name);
2.发送文本消息:ws.send(msg);
3.接受消息:ws.onmessage = (function(){...})();
4.错误处理:ws.onerror = (function(){...})();
5.关闭连接:ws.close();
var socket;
if(typeof(WebSocket) == "undefined") {
alert("您的浏览器不支持WebSocket");
return;
}
//连接
$("#btnConnection").click(function() {
//实例化WebSocket对象,指定要连接的服务器地址与端口
socket = new WebSocket("ws://192.168.1.2:8888");
//打开事件
socket.onopen = function() {
alert("Socket 已打开");
socket.send("这是来自客户端的消息" + location.href + new Date());
};
//获得消息事件
socket.onmessage = function(msg) {
alert(msg.data);
};
//关闭事件
socket.onclose = function() {
alert("Socket已关闭");
};
//发生了错误事件
socket.onerror = function() {
alert("发生了错误");
}
});
服务端:
1.监听客户端连接 io.on('connection',socket=>{ })
socket.io的基本使用的更多相关文章
- 在web浏览器上显示室内温度(nodeJs+arduino+socket.io)
上次的nodejs操作arduino入门篇中实现了如何连接arduino.这次我们来实现通过arduino测量室内温度并在浏览器上显示出来. [所需材料] 硬件:LM35温度传感器,arduino u ...
- Node学习笔记(三):基于socket.io web版你画我猜(二)
上一篇基础实现的功能是客户端canvas作图,导出dataURL从而实现图片信息推送,下面具体讲下服务端的配置及客户端的配置同步 首先先画一个流程图,讲下大概思路 <canvas id=&quo ...
- node.js+socket.io配置详解
由于我是在win7的环境下,在这里就以win7系统为例进行讲解了. 首先需要在nodejs官网下载最新版的node.js,下载完毕直接安装即可,安装成功后在cmd命令行中执行node指令,如下结果就说 ...
- 使用Node.js+Socket.IO搭建WebSocket实时应用
Web领域的实时推送技术,也被称作Realtime技术.这种技术要达到的目的是让用户不需要刷新浏览器就可以获得实时更新.它有着广泛的应用场景,比如在线聊天室.在线客服系统.评论系统.WebIM等. W ...
- socket.io简单入门(一.实现简单的图表推送)
引子:随着nodejs蓬勃发展,虽然主要业务系统因为架构健壮性不会选择nodejs座位应用服务器.但是大量的内部系统却可以使用nodejs试水,大量的前端开发人员转入全堆开发也是一个因素. 研究本例主 ...
- websocket与socket.io
什么是Websocket? Websocket是一个独立于http的实时通信协议,最初是在HTML5中被引用进来的,在HTML5规范中作为浏览器与服务器的核心通信技术被嵌入到浏览器中.WebSocke ...
- socket.io安装部署
需要node.js环境 创建package.json npm init 下载相关依赖 npm install --save express@4.10.2npm会在当前目录下载所需要的依赖到node_m ...
- Node.js、Express、Socket.io 入门
前言 周末断断续续的写了第一个socket.io Demo.初次接触socket.io是从其官网看到的,看着get started做了一遍,根据官网的Demo能提供简单的服务端和客户端通讯. 这个De ...
- socket.io,io=Manager(source, opts)
原文:http://www.cnblogs.com/xiezhengcai/p/3968067.html 当我们在使用 var socket = io("ws://103.31.201.15 ...
- socket.io,命名空间
原文:http://www.cnblogs.com/xiezhengcai/p/3966263.html 命名空间 在api部分我们说io.connect('ws://103.31.201.154:5 ...
随机推荐
- Shutdown- Linux必学的60个命令
1.作用 shutdown命令的作用是关闭计算机,它的使用权限是超级用户. 2.格式 shutdown [-h][-i][-k][-m][-t] 3.重要参数 -t:在改变到其它运行级别之前,告诉in ...
- openSUSE中启用apache mod_rewrite
1. 编辑 "/etc/sysconfig/apache2"文件 查找 APACHE_MODULES,你应该会找到一行像 APACHE_MODULES="actions ...
- mysql 存中文失败问题
在向数据库存中文时报错: 将中文字段的字符集改为utf8即可: 成功截图:
- 线段树分治初步学习&洛谷P5227[AHOI2013]连通图
线段树分治 其实思想说起来是比较简单的,我们把这个题里的所有操作(比如连边删边查询balabala)全部拍到一棵线段树上,然后对着整棵树dfs一下求解答案,顺便把操作做一下,回溯的时候撤销一下即可.虽 ...
- Python(四)基础篇之「文件对象&错误处理」
[笔记]Python(四)基础篇之「文件对象&错误处理」 2016-12-08 ZOE 编程之魅 Python Notes: ★ 如果你是第一次阅读,推荐先浏览:[重要公告]文章更新. ...
- mysql表时间戳字段设置
创建时间 修改时间
- SprigBoot中的 WebMvcConfigurer与 WebMvcConfigurerAdapter和 WebMvcConfigurationSupport
WebMvcConfigurationAdapter 过时? 在SpringBoot2.0之后的版本中WebMvcConfigurerAdapter过时了,所以我们一般采用的是如下的两种的解决的方法. ...
- 网络结构解读之inception系列二:GoogLeNet(Inception V1)
网络结构解读之inception系列二:GoogLeNet(Inception V1) inception系列的开山之作,有网络结构设计的初期思考. Going deeper with convolu ...
- 洛谷 P1155 双栈排序
题面 解题思路 这道题乍一看还以为是个模拟..怒写一发30分(noip提高组t4有模拟吗?). 其实很好hack,如 10 10 2 8 1 7 9 3 4 5 6 按模拟的思路,应该是10入第一个栈 ...
- 深入浅出 Java Concurrency (12): 锁机制 part 7 信号量(Semaphore)[转]
Semaphore 是一个计数信号量.从概念上讲,信号量维护了一个许可集.如有必要,在许可可用前会阻塞每一个 acquire(),然后再获取该许可.每个 release() 添加一个许可,从而可能释放 ...