来源:未知 时间:2017-09-26 10:50 作者:xxadmin 阅读:次
[导读] 在HTML5规范中,我最喜欢的Web技术就是正迅速变得流行的WebSocket API。WebSocket提供了一个受欢迎的技术,以替代我们过去几年一直在用的Ajax技术。这个新的API提供了一个方法,从客户端使...
在HTML5规范中,我最喜欢的Web技术就是正迅速变得流行的WebSocket API。WebSocket提供了一个受欢迎的技术,以替代我们过去几年一直在用的Ajax技术。这个新的API提供了一个方法,从客户端使用简单的语法有效地推动消息到服务器。让我们看一看HTML5的WebSocket API:它可用于客户端、服务器端。而且有一个优秀的第三方API,名为Socket.IO。 // 创建一个Socket实例 var socket = new WebSocket('ws://localhost:8080'); // 打开Socket socket.onopen = function(event) { // 发送一个初始化消息 socket.send('I am the client and I\'m listening!'); // 监听消息 socket.onmessage = function(event) { console.log('Client received a message',event); }; // 监听Socket的关闭 socket.onclose = function(event) { console.log('Client notified socket has closed',event); }; // 关闭Socket.... //socket.close() };
<script src="http://cdn.socket.io/stable/socket.io.js"></script> // 创建Socket.IO实例,建立连接 var socket= new io.Socket('localhost',{ port: 8080 }); socket.connect(); // 添加一个连接监听器 socket.on('connect',function() { console.log('Client has connected to the server!'); }); // 添加一个连接监听器 socket.on('message',function(data) { console.log('Received a message from the server!',data); }); // 添加一个关闭连接的监听器 socket.on('disconnect',function() { console.log('The client has disconnected!'); }); // 通过Socket发送一条消息到服务器 function sendMessageToServer(message) { socket.send(message); }
// 需要HTTP 模块来启动服务器和Socket.IO var http= require('http'), io= require('socket.io'); // 在8080端口启动服务器 var server= http.createServer(function(req, res){ // 发送HTML的headers和message res.writeHead(200,{ 'Content-Type': 'text/html' }); res.end('<h1>Hello Socket Lover!</h1>'); }); server.listen(8080); // 创建一个Socket.IO实例,把它传递给服务器 var socket= io.listen(server); // 添加一个连接监听器 socket.on('connection', function(client){ // 成功!现在开始监听接收到的消息 client.on('message',function(event){ console.log('Received message from client!',event); }); client.on('disconnect',function(){ clearInterval(interval); console.log('Server has disconnected'); }); });
node socket-server.js
// 创建一个定期(每5秒)发送消息到客户端的发送器 var interval= setInterval(function() { client.send('This is a message from the server! ' + new Date().getTime()); },5000);
var args, ws= typeof WebSocket!= 'undefined'; var socket= dojox.socket(args= { url: ws? '/socket.io/websocket' : '/socket.io/xhr-polling', headers:{ 'Content-Type':'application/x-www-urlencoded' }, transport: function(args, message){ args.content = message; // use URL-encoding to send the message instead of a raw body dojo.xhrPost(args); }; }); var sessionId; socket.on('message', function(){ if (!sessionId){ sessionId= message; args.url += '/' + sessionId; }else if(message.substr(0, 3) == '~h~'){ // a heartbeat } }); dojox.socket.Reconnect还创建了在套接字失去连接时自动重连。期待包含dojox.Socket的Dojo 1.6版本早日发布。 |
自学PHP网专注网站建设学习,PHP程序学习,平面设计学习,以及操作系统学习
京ICP备14009008号-1@版权所有www.zixuephp.com
网站声明:本站所有视频,教程都由网友上传,站长收集和分享给大家学习使用,如由牵扯版权问题请联系站长邮箱904561283@qq.com