1、安裝socket.io
npm install socket.io
2、創建服務端代碼server.js
var app = require('http').createServer(handler), io = require('socket.io').listen(app), fs = require('fs') app.listen(8080); io.set('log level', 1);//將socket.io中的debug信息關閉 function handler (req, res) { fs.readFile(__dirname + '/index.html',function (err, data) { if (err) { res.writeHead(500); return res.end('Error loading index.html'); } res.writeHead(200, {'Content-Type': 'text/html'}); res.end(data); }); } io.sockets.on('connection', function (socket) { socket.emit('news', { hello: 'world' }); socket.on('my other event', function (data) { console.log(data); }); });
3、創建客戶端代碼 index.html
<!DOCTYPE html> <html lang="en"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>Ssocket</title> <script type="text/javascript" src="http://localhost:8080/socket.io/socket.io.js"></script> </head> <body> <script type="text/javascript"> var socket = io.connect('http://localhost:8080'); socket.on('news', function (data) { alert(data.hello); socket.emit('my other event', { my: 'data' }); }); </script> </body> </html>
4、執行結果
啟動服務端:
node server.js
在瀏覽器輸入 http://localhost:8080/index.html
瀏覽器打印出: world
命令行打印出:{ my: 'data' }
5、更多資料參見官方網站 http://socket.io/#how-to-use
6、服務端向指定客戶端發送消息
思路是客戶端與服務端建立連接的時候,服務端保存客戶端的信息,做一個socketMap, 在socketMap中取出需要發送消息的客戶端,向該客戶端發送消息
做一個模擬的簡單例子,這里用的是數組:
var sockets = []; var i = 1; io.sockets.on('connection', function (socket) { sockets[i] = socket; i++; socket = sockets[1]; //這里指定向第一個客戶發送消息 console.log(i); socket.emit('news', { hello: 'world' }); socket.on('my other event', function (data) { console.log(data); }); });