一、安装socket.iojavascript
npm install socket.io
二、建立服务端代码server.jshtml
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); }); });
三、建立客户端代码 index.htmljava
<!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>
四、执行结果node
启动服务端:npm
node server.js
在浏览器输入 http://localhost:8080/index.html数组
浏览器打印出: world浏览器
命令行打印出:{ my: 'data' }app
五、更多资料参见官方网站 http://socket.io/#how-to-usesocket
六、服务端向指定客户端发送消息网站
思路是客户端与服务端创建链接的时候,服务端保存客户端的信息,作一个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); }); });