[Node.js] Level 6. Socket.io
6.2 Setting Up socket.io Server-Side
So far we've created an Express server. Now we want to start building a real-time Q&A moderation service and we've decided to use socket.io.
Using the http module, create an new http server and pass the expressapp as the listener for that new server.
var express = require('express');
var app = express();
var server = require('http').createServer(app);
Using the socket.io module, listen for requests on the http server. Store the return object of this operation in a variable called io.
var io = require('socket.io')(server);
Use the object stored in io to listen for client 'connection' events. Remember, the callback function takes one argument, which is the client object that has connected.
When a new client connects, log a message using console.log().
io.on('connection', function(client){
console.log(client + "has connected.");
});
Finally, we want to tell our http server to listen to requests on port 8080.
server.listen(8080);
Code:
var express = require('express');
var app = express();
var server = require('http').createServer(app);
var io = require('socket.io')(server);
io.on('connection', function(client){
console.log(client + "has connected.");
});
server.listen(8080);
6.3 Client socket.io Setup
In our html file, load the socket.io.js script and connect to the socket.io server.
Load the socket.io.js script. The socket.io.js path you should use is'/socket.io/socket.io.js'. Express knows to serve the socket.io client js for this path.
Using the global io object that's now available for us, connect to the socket.io server at http://localhost:8080.
<script src="/socket.io/socket.io.js"></script> <script>
var server = io.connect('http://localhost:8080');
</script><script></script>
6.4 Listening For Questions
In our client below, listen for 'question' events from the server and call the insertQuestion function whenever the event fires.
First, listen for 'question' events from the server.
Now, have the event callback function call the insertQuestion function. TheinsertQuestion function is already created for you, and it's placed in its own file. It expects exactly one argument - the question.
server.on('question', function(data){
insertQuestion(data);
});
Code:
<script src="/socket.io/socket.io.js"></script>
<script src="/insertQuestion.js"></script> <script>
var server = io.connect('http://localhost:8080'); // Insert code here
server.on('question', function(data){
insertQuestion(data);
});
</script>
6.5 Broadcasting Questions
When a question is submitted to our server, we want to broadcast it out to all the connected clients so they can have a chance to answer it.
In the server, listen for 'question' events from clients.
client.on('question', function(question){
});
Now, emit the 'question' event on all the other clients connected, passing them the question data.
client.broadcast.emit('question', question);
Code:
var express = require('express');
var app = express();
var server = require('http').createServer(app);
var io = require('socket.io')(server);
io.on('connection', function(client) {
console.log("Client connected...");
client.on('question', function(question){
client.emit('question', question);
});
});
server.listen(8080);
6.6 Saving Client Data
In our real-time Q&A app, we want to allow each client only one question at a time, but how do we enforce this rule? We can use socket.io's ability to save data on the client, so whenever a question is asked, we first want to check the question_asked value on the client.
First, when a client emits a 'question' event, we want to set the value ofquestion_asked to true.
Second, when a client emits a 'question' event, we want to broadcast that question to the other clients.
client.question_asked = true;
client.broadcast.emit('question', question);
Finally, when a client emits a 'question' event, check to make surequestion_asked is not already set to true. We only want to allow one question per user, so make sure that we only set the value ofquestion_asked and broadcast the question to other clients when the value of question_asked is not already true.
var express = require('express');
var app = express();
var server = require('http').createServer(app);
var io = require('socket.io')(server);
io.on('connection', function(client) {
console.log("Client connected...");
client.on('question', function(question) {
if(!client.question_asked){
client.question_asked = true;
client.broadcast.emit('question', question);
}
});
});
server.listen(8080);
6.7 Answering Questions
Clients can also answer each other's questions, so let's build that feature by first listening for the 'answer' event on the client, which will send us both the question and answer, which we want to broadcast out to the rest of the connected clients.
With the client, listen for the 'answer' event from clients.
client.on('answer', function(question, answer){
});
Now, emit the 'answer' event on all the other clients connected, passing them the question data.
// listen for answers here
client.on('answer', function(question, answer){
client.broadcast.emit('answer', question, answer);
});
6.8 Answering Question Client
Now on the client, listen for the 'answer' event and then broadcast both the question and the answer to the connected clients.
Listen for the 'answer' event off of the server.
Call the answerQuestion function, passing in both the question and theanswer that was broadcast from the server.
<script src="/socket.io/socket.io.js"></script> <script>
var server = io.connect('http://localhost:8080'); server.on('question', function(question) {
insertQuestion(question);
}); server.on('answer', function(question, answer){
answerQuestion(question, answer);
}); //Don't worry about these methods, just assume
//they insert the correct html into the DOM
// var insertQuestion = function(question) {
// } // var answerQuestion = function(question, answer) {
// }
</script>
[Node.js] Level 6. Socket.io的更多相关文章
- node.js中使用socket.io + express进行实时消息推送
socket.io是一个websocket库,包含客户端的js和服务端的node.js,可以在不同浏览器和移动设备上构建实时应用. 一.安装 socket.io npm install socket. ...
- node基于express的socket.io
前一段事件,我一个同学给他们公司用融云搭建了一套web及时通信系统,然后之前我的公司也用过环云来实现web及时通信,本人对web及时通信还是非常感兴趣的.私下读了融云和环信的开发文档,然后发现如果注册 ...
- [Node.js]29. Level 6: Socket.io: Setting up Socket.io server-side & Client socket.io setup
Below we've already created an express server, but we want to start building a real-time Q&A mod ...
- dotnet调用node.js写的socket服务(websocket/socket/socket.io)
https://github.com/jstott/socketio4net/tree/develop socket.io服务端node.js,.里面有js写的客户端:http://socket.io ...
- Node.js入门:异步IO
异步IO 在操作系统中,程序运行的空间分为内核空间和用户空间.我们常常提起的异步I/O,其实质是用户空间中的程序不用依赖内核空间中的I/O操作实际完成,即可进行后续任务. 同步IO的并行模式 ...
- [Node.js] Level 7. Persisting Data
Simple Redis Commands Let's start practicing using the redis key-value store from our node applicati ...
- [Node.js] Level 3 new. Steam
File Read Stream Lets use the fs module to read a file and log its contents to the console. Use the ...
- [Node.js] Level 2 new. Event
Chat Emitter We're going to create a custom chat EventEmitter. Create a new EventEmitter object and ...
- [Node.js] Level 5. Express
Express Routes Let's create an express route that accepts GET requests on'/tweets' and responds by s ...
随机推荐
- python 计算md5
import hashlib src = "afnjanflkas" m2 = hashlib.md5() m2.update(src) print m2.hexdigest() ...
- CUDA学习笔记4:CUDA(英伟达显卡统一计算架构)代码运行时间测试
CUDA内核运行时间的测量函数 cudaEvent_t start1; cudaEventCreate(&start1); cudaEvent_t stop1; cudaEventCreate ...
- input限制中文字数
我们知道input控件有一个maxlength属性可以控制输入字符的长度,但是,它并不会识别是汉字还是其他符号,所以输入maxlength个汉字显然是不符合要求的. 为了实现对带有汉字的输入框长度控制 ...
- BZOJ2434 NOI2011阿狸的打字机
询问x这个串在y中出现的次数. fail数组有一个性质就是一旦a的fail指向b那么b所代表的字串一定是a的后缀. 所以我们看fail树(即按fail反向建树)中x的子树有多少y的结点即可. 这个操作 ...
- 「SCOI2016」美味
「SCOI2016」美味 题目描述 一家餐厅有 \(n\) 道菜,编号 \(1 \ldots n\) ,大家对第 \(i\) 道菜的评价值为 \(a_i \:( 1 \leq i \leq n )\) ...
- 【四边形不等式】HDU3506-Monkey Party
[题目大意] 香蕉森林里一群猴子(n<=1000)围成一圈开会,会长给他们互相介绍,每个猴子需要时间a[i].每次只能介绍相邻的两只猴子x和y认识,同时x所有认识的猴子和y所有认识的猴子也就相互 ...
- bzoj 1458: 士兵占领 -- 最大流
1458: 士兵占领 Time Limit: 10 Sec Memory Limit: 64 MB Description 有一个M * N的棋盘,有的格子是障碍.现在你要选择一些格子来放置一些士兵 ...
- [转]JSONObject,JSONArray使用手册
您的评价: 收藏该经验 这两个是官网的API JSONObject API JSONArray API 里面有这两个类的所有方法,是不可多得的好材料哦~ 配合上面的API ...
- 51NOD 1179 最大的最大公约数 筛法
1179 最大的最大公约数 题目连接: https://www.51nod.com/onlineJudge/questionCode.html#!problemId=1179 Description ...
- PAT甲级1095. Cars on Campus
PAT甲级1095. Cars on Campus 题意: 浙江大学有6个校区和很多门.从每个门口,我们可以收集穿过大门的汽车的进/出时间和车牌号码.现在有了所有的信息,你应该在任何特定的时间点告诉在 ...