理解socket.io(一)---相关的API
理解socket.io(一)---相关的API
1. 什么是Socket.IO?
Socket.IO是node.js的一个模块,它用于浏览器与服务端之间实时通信。它提供了服务器和客户端的组件,只需一个模块就可以给应用程序对webSocket的支持。Socket.IO解决了各个浏览器支持的问题。
2. Socket.IO支持如下方式进行通信,会根据浏览器的支持程度,自动选择使用哪种技术进行通信:
WebSocket
Flash Socket
AJAX long-polling
AJAX multiple streaming
Forever IFrame
JSONP polling
3. Socket.IO的API
// 监听客户端连接,回调函数会传递本次连接的socket
io.on('connection', function(socket){}); // 给所有客户端广播消息
io.sockets.emit('event_name', data); // 给指定的客户端发送消息
io.sockets.socket(socketid).emit('event_name', data); // 监听发送的消息
socket.on('event_name', function(data) {}); // 给该socket的客户端发送消息
socket.emit('event_name', data); // 给除了自己以外的客户端广播消息
socket.broadcast.emit("event_name", data);
客户端:
1. 建立一个socket连接
var socket = io("ws:///xxxxx");
2. 监听服务消息
socket.on('msg', function(data) {
socket.emit('msg', {xx: xx1}); // 向服务器发送消息
console.log(data);
});
3. 监听socket断开
socket.on('disconnect', function(){
console.log('与服务器断开');
});
4. 监听socket的重连
socket.on('reconnect', function() {
console.log('重新连接到服务器');
});
客户端socket.on()监听的事件:
connect: 连接成功
connecting: 正在连接
disconnect: 断开连接
connect_failed: 连接失败
error: 发生错误
message: 接收到消息事件
reconnect_failed: 重连失败
reconnect: 重连成功
reconnecting: 正在重连
1-1:给当前的客户端发送消息的demo
下面我们简单的来看一个demo,页面有一个文本域和一个按钮,点击按钮后。
首先需要安装一下 socket.io;
命令行如下:
npm install --save socket.io
以下是项目中package.json,如下:
{
"name": "socket-demo1",
"version": "1.0.0",
"description": "",
"main": "index.js",
"scripts": {
"test": "echo \"Error: no test specified\" && exit 1"
},
"author": "",
"license": "ISC",
"dependencies": {
"socket.io": "^2.1.0"
},
"devDependencies": {
"fs": "0.0.1-security",
"http": "0.0.0"
}
}
html代码如下:
<!DOCTYPE html>
<html>
<head>
<title>socket.io node.js</title>
<style> </style>
</head>
<body>
<h1>socket.io</h1>
<form action="#" id="form">
<textarea id="message" cols="30" rows="10"></textarea>
<input type="submit" value="send message" id="submit"/>
</form>
<script src="http://localhost:3000/socket.io/socket.io.js"></script>
<script>
var socket = io.connect('http://127.0.0.1:3000');
var msg = document.getElementById('message');
var submit = document.getElementById('submit');
submit.onclick = function(e) {
socket.emit('msg', {text: msg.value}); // 发生textarea的值给服务器
return false;
};
// 监听msg事件
socket.on('msg', function(data) {
console.log(data);
})
</script>
</body>
</html>
app.js代码如下:
var http = require('http');
var fs = require('fs');
var server = http.createServer(function(res, res) {
fs.readFile('./index.html', function(err, data){
res.writeHead(200, { 'Content-Type': 'text/html' });
res.end(data, 'utf-8');
})
}).listen(3000, '127.0.0.1');
console.log('server running at http://127.0.0.1:3000');
var io = require('socket.io').listen(server);
io.sockets.on('connection', function(socket) {
// 侦听客户端的msg事件
socket.on('msg', function(data) {
// 给除了自己以外的客户端广播消息
// socket.broadcast.emit('msg', data);
// 给当前的客户端发送消息
socket.emit('msg', data);
})
});
进入对应的项目,命令行 运行 node app.js, 然后在浏览器下运行 http://127.0.0.1:3000/ 后即可,发送消息后,在控制台看到能监听到消息;
简单代码分析:
首先是通过点击按钮,获取到文本域的值,然后使用 socket.emit('msg', {text: msg.value}); 发送消息,服务器端(也就是app.js)代码内通过
io.sockets.on('connection', function(socket) {}), 该函数能监听客户端连接,然后使用 socket.on('msg', function(data) {})能监听到客户端的msg事件,
最后通过 socket.emit('msg', data); 给客户端发送消息,最后客户端通过如下代码就能监听服务端回来的消息。
// 监听msg事件
socket.on('msg', function(data) {
console.log(data);
})
// 因此 整个代码如下:
io.sockets.on('connection', function(socket) {
// 侦听客户端的msg事件
socket.on('msg', function(data) {
// 给当前的客户端发送消息
socket.emit('msg', data);
})
})
1-2: 如果想给除了自己以外的客户端广播消息
可以把上面客户端的代码 socket.emit('msg', data); 改成 socket.broadcast.emit('msg', data);
因此打开浏览器访问http://127.0.0.1:3000,同时打开另一个浏览器或者多个浏览器,浏览http://127.0.0.1:3000,当在第一个标签页的发送消息的时候,在第二个标签页面或其他标签页面的控制台可以看到消息。
1-3:如果想给当前所有的客户端都发送消息的话,需要发送广播消息,代码可以改成如下:
io.sockets.on('connection', function(socket) {
// 侦听客户端的msg事件
socket.on('msg', function(data) {
// 给除了自己以外的客户端广播消息
socket.broadcast.emit('msg', data);
// 给当前的客户端发送消息
socket.emit('msg', data);
})
});
二. 实现一个简单的计数器来监听服务器上所连接客户端的数量。
思路是:当服务器启动后,计算器是从0开始,当打开浏览器访问http://127.0.0.1:3000后,客户端连接到服务器时它就增加1,当关闭一个浏览器时,它就
减少1。这或是可以理解为 站点实时统计访问者的数据的一个简单的列子吧。
app.js 代码如下:
var http = require('http');
var fs = require('fs');
var count = 0;
var server = http.createServer(function(res, res) {
fs.readFile('./index.html', function(err, data){
res.writeHead(200, { 'Content-Type': 'text/html' });
res.end(data, 'utf-8');
})
}).listen(3000, '127.0.0.1');
console.log('server running at http://127.0.0.1:3000');
var io = require('socket.io').listen(server);
io.sockets.on('connection', function(socket) {
count++;
console.log("user connected" + count + 'users');
socket.emit('users', {number: count});
socket.broadcast.emit('users', {number: count});
socket.on('disconnect', function() {
count--;
console.log('user disconnected' + count + 'users');
socket.broadcast.emit('users', {number: count});
});
});
html代码如下:
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8"/>
<title>socket.io node.js</title>
<style> </style>
</head>
<body>
<h3>socket.io实时监听服务器上所连接客户端的数量</h3>
<p id="count"></p> <script src="http://localhost:3000/socket.io/socket.io.js"></script>
<script>
var socket = io.connect('http://127.0.0.1:3000');
var count = document.getElementById('count'); // 侦听users的事件
socket.on('users', function(data) {
console.log(data);
count.innerHTML = data.number;
});
</script>
</body>
</html>
理解socket.io(一)---相关的API的更多相关文章
- socket.io,理解socket.io
原文:http://www.cnblogs.com/xiezhengcai/p/3957314.html 要理解socket.io ,不得不谈谈websocket 在html5之前,因为http协议是 ...
- SOCKET.IO 的用法 系统API,
原文:http://www.cnblogs.com/xiezhengcai/p/3956401.html 1. 服务端 io.on('connection',function(socket)); 监听 ...
- Websocket --socket.io的用法
<!DOCTYPE html> <html> <head> <title>Hello WebSocket</title> <link ...
- socket.io,系统api,
原文:http://www.cnblogs.com/xiezhengcai/p/3956401.html 1. 服务端 io.on('connection',function(socket)); 监听 ...
- koa+mysql+vue+socket.io全栈开发之web api篇
目标是建立一个 web QQ的项目,使用的技术栈如下: 后端是基于koa2 的 web api 服务层,提供curd操作的http接口,登录验证使用的是 json web token,跨域方案使用的是 ...
- socket.io常用api
1. 服务端 io.on('connection',function(socket)); 监听客户端连接,回调函数会传递本次连接的socket io.sockets.emit('String',dat ...
- socket.io 中文api
1. 服务端 io.on('connection',function(socket)); 监听客户端连接,回调函数会传递本次连接的socket io.sockets.emit('String',dat ...
- node相关--socket.io
使用Socket.IO可以避免webSocket产生的问题: 传输: Socket.IO中消息的传递是基于传输的,而非全部依靠WebSocket; 它总会尝试选择对用户来说速度最快.对服务器性能来说最 ...
- 【socket.io研究】1.官网的一些相关说明,概述
socket.io是什么? 官网的解释是一个实时的,基于事件的通讯框架,可以再各个平台上运行,关注于效率和速度. 在javascript,ios,android,java中都实现了,可以很好的实现实时 ...
随机推荐
- Nginx + 阿里云SSL + tomcat 实现https访问代理
第一步:阿里云申请云盾证书服务 第二步:下载证书 第三步:修改Nginx配置 1. 证书文件214033834890360.pem,包含两段内容,请不要删除任何一段内容. 2. 如果是证书系统创建的C ...
- HDU3567
Eight II Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 130000/65536 K (Java/Others)Total S ...
- table垂直居中
th,td{ text-align:center;/** 设置水平方向居中 */ vertical-align:middle/** 设置垂直方向居中 */ }
- javascript:jQuery tablesorter 2.0
https://mottie.github.io/tablesorter/docs/index.html 1.GridView <%@ Page Language="C#" ...
- JS的DOM操作 - 你真的了解吗?
摘要 想稍微系统的说说对于DOM的操作,把Javascript和jQuery常用操作DOM的内容归纳成思维导图方便阅读,同时加入性能上的一些问题. 前言 在前端开发的过程中,javascript极为重 ...
- 2017-12-05 JavaScript实现ZLOGO子集: 前进+转向
在前文中文编程语言之Z语言初尝试: ZLOGO 4与相关讨论后, 萌生了用JavaScript编写类似语言以便在线编程的想法. 于是使用 @TKT2016 (知乎账号)的ZLOGO语法设计, 在编程语 ...
- angularjs的$http请求方式
/*$http常用的几个参数 $http服务的设置对象: 1.method 字符串 表示发送的请求类型 get post jsonp等等 2.url 字符串 绝对或者相对的URL,请求的目标 3.pa ...
- JAVA学习笔记:注释、变量的声明和定义、
本文内容: 注释 变量的声明和定义 成员变量和局部变量 首发时间:2018-03-16 15:59 注释: 单行注释:// 多行注释:/* - */ 变量: 变量是内存中的一个存储区域,变量的定义就是 ...
- 通用triggerEvent方法
假设有一个id为testA的a元素,然后有以下代码(jquery已存在): $(document).ready(function(){ $('#testA').on('testEvent', func ...
- 第四周读书笔记——读《我是一只IT小小鸟》有感
读<我是一只IT小小鸟>有感 这是邓老师倾力推荐的一本书.这本书的标题化用了我们耳熟能详的歌词,算是较有新意吧.更重点在于,这本书的作者不是哪一位大牛,而是一群刚刚走出校 ...