主页 > 前端 > javascript >
来源:自学PHP网 时间:2017-06-06 10:05 作者: 阅读:次
[导读] 这篇文章主要介绍了nodejs socket实现的服务端和客户端功能,结合具体实例形式分析了nodejs基于socket通信实现的服务端与客户端功能相关操作技巧,需要的朋友可以参考下...
本文实例讲述了nodejs socket实现的服务端和客户端功能。分享给大家供大家参考,具体如下: 使用node.js的net模块能很快的开发出基于TCP的服务端和客户端。直接贴代码。 server.js /** * Created with JetBrains WebStorm. * User: Administrator * Date: 12-10-26 * Time: 下午3:44 * To change this template use File | Settings | File Templates. */ var net = require('net'); var timeout = 20000;//超时 var listenPort = 7003;//监听端口 var server = net.createServer(function(socket){ // 我们获得一个连接 - 该连接自动关联一个socket对象 console.log('connect: ' + socket.remoteAddress + ':' + socket.remotePort); socket.setEncoding('binary'); //超时事件 // socket.setTimeout(timeout,function(){ // console.log('连接超时'); // socket.end(); // }); //接收到数据 socket.on('data',function(data){ console.log('recv:' + data); }); //数据错误事件 socket.on('error',function(exception){ console.log('socket error:' + exception); socket.end(); }); //客户端关闭事件 socket.on('close',function(data){ console.log('close: ' + socket.remoteAddress + ' ' + socket.remotePort); }); }).listen(listenPort); //服务器监听事件 server.on('listening',function(){ console.log("server listening:" + server.address().port); }); //服务器错误事件 server.on("error",function(exception){ console.log("server error:" + exception); }); client.js /** * Created with JetBrains WebStorm. * User: Administrator * Date: 12-10-26 * Time: 下午3:56 * To change this template use File | Settings | File Templates. */ var net = require('net'); var port = 7003; var host = '127.0.0.1'; var client= new net.Socket(); client.setEncoding('binary'); //连接到服务端 client.connect(port,host,function(){ client.write('hello my client'); }); client.on('data',function(data){ console.log('recv data:'+ data); }); client.on('error',function(error){ console.log('error:'+error); client.destory(); }); client.on('close',function(){ console.log('Connection closed'); }); 希望本文所述对大家nodejs程序设计有所帮助。 |
自学PHP网专注网站建设学习,PHP程序学习,平面设计学习,以及操作系统学习
京ICP备14009008号-1@版权所有www.zixuephp.com
网站声明:本站所有视频,教程都由网友上传,站长收集和分享给大家学习使用,如由牵扯版权问题请联系站长邮箱904561283@qq.com