node.js使用net模塊創(chuàng)建服務(wù)器和客戶端示例【基于TCP協(xié)議】
本文實(shí)例講述了node.js使用net模塊創(chuàng)建服務(wù)器和客戶端。分享給大家供大家參考,具體如下:
node.js中net模塊創(chuàng)建服務(wù)器和客戶端
1.node.js中net模塊創(chuàng)建服務(wù)器(net.createServer)
// 將net模塊 引入進(jìn)來(lái)
var net = require("net");
// 創(chuàng)建一個(gè)net.Server用來(lái)監(jiān)聽,當(dāng)連接進(jìn)來(lái)的時(shí)候,就會(huì)調(diào)用我們的函數(shù)
// client_sock,就是我們的與客戶端通訊建立連接配對(duì)的socket
// client_sock 就是與客戶端通訊的net.Socket
var server = net.createServer(function(client_sock) {
console.log("client comming", client_sock.remoteAddress, client_sock.remotePort);
// 設(shè)置你接受的格式,
// client_sock.setEncoding("utf8");
// client_sock.setEncoding("hex"); // 轉(zhuǎn)成二進(jìn)制的文本編碼
//
// 客戶端斷開連接的時(shí)候處理,用戶斷線離開了
client_sock.on("close", function() {
console.log("close socket");
});
// 接收到客戶端的數(shù)據(jù),調(diào)用這個(gè)函數(shù)
// data 默認(rèn)是Buffer對(duì)象,如果你強(qiáng)制設(shè)置為utf8,那么底層會(huì)先轉(zhuǎn)換成utf8的字符串,傳給你
// hex 底層會(huì)把這個(gè)Buffer對(duì)象轉(zhuǎn)成二進(jìn)制字符串傳給你
// 如果你沒(méi)有設(shè)置任何編碼 <Buffer 48 65 6c 6c 6f 57 6f 72 6c 64 21>
// utf8 --> HelloWorld!!! hex--> "48656c6c6f576f726c6421"
client_sock.on("data", function(data) {
console.log(data);
client_sock.write("goodbye!!!");
client_sock.end(); // 正常關(guān)閉
});
client_sock.on("error", function(err) {
console.log("error", err);
});
});
// 當(dāng)我開始監(jiān)聽的時(shí)候就會(huì)調(diào)用這個(gè)回掉函數(shù)
server.on("listening", function() {
console.log("start listening...");
});
// 監(jiān)聽發(fā)生錯(cuò)誤的時(shí)候調(diào)用
server.on("error", function() {
console.log("listen error");
});
server.on("close", function() {
console.log("server stop listener");
});
/*
server.on("connection", function(client_sock) {
console.log("client comming 22222");
});
*/
// 編寫代碼,指示這個(gè)server監(jiān)聽到哪個(gè)端口上面。
// 127.0.0.1: 6080
// node就會(huì)來(lái)監(jiān)聽我們的server,等待連接接入
server.listen({
port: 6080,
host: "127.0.0.1",
exclusive: true,
});
// 停止node對(duì)server的監(jiān)聽事件處理,那么node就沒(méi)有其他的事件要處理,所以就退出了。
// server.unref(); // 取消node,對(duì)server的事件的監(jiān)聽;
// server.close(); // 主動(dòng)的掉這個(gè)server.close才會(huì)觸發(fā)這個(gè)net.Server的close事件
2.node.js中net模塊創(chuàng)建客戶端(net.connect())
var net = require("net");
// net.Socket,
var sock = net.connect({
port: 6080,
host: "127.0.0.1",
}, function() {
console.log('connected to server!');
});
// 連接成功調(diào)用的事件
sock.on("connect",function() {
console.log("connect success");
// 在這里我們就可以發(fā)送數(shù)據(jù)了
sock.write("HelloWorld!", "utf8");
// end
});
// end
// 有錯(cuò)誤發(fā)生調(diào)用的事件
sock.on("error", function(e) {
console.log("error", e);
});
// socket關(guān)閉的事件
sock.on("close", function() {
console.log("close");
});
// 對(duì)方發(fā)送了關(guān)閉數(shù)據(jù)包過(guò)來(lái)的事件
sock.on("end", function() {
console.log("end event");
});
// 當(dāng)有數(shù)據(jù)發(fā)生的時(shí)候,調(diào)用;
sock.on("data", function(data) {
console.log(data);
});
希望本文所述對(duì)大家node.js程序設(shè)計(jì)有所幫助。
相關(guān)文章
node.js應(yīng)用后臺(tái)守護(hù)進(jìn)程管理器Forever安裝和使用實(shí)例
這篇文章主要介紹了node.js應(yīng)用后臺(tái)守護(hù)進(jìn)程管理器Forever安裝和使用實(shí)例,forever可以看做是一個(gè)nodejs的守護(hù)進(jìn)程,能夠啟動(dòng),停止,重啟我們的app應(yīng)用,需要的朋友可以參考下2014-06-06
Node.JS枚舉統(tǒng)計(jì)當(dāng)前文件夾和子目錄下所有代碼文件行數(shù)
這篇文章主要介紹了Node.JS枚舉統(tǒng)計(jì)當(dāng)前文件夾和子目錄下所有代碼文件行數(shù),本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-08-08
node.js+Ajax實(shí)現(xiàn)獲取HTTP服務(wù)器返回?cái)?shù)據(jù)
這篇文章主要介紹了node.js+Ajax實(shí)現(xiàn)獲取HTTP服務(wù)器返回?cái)?shù)據(jù),講解的十分詳細(xì),也給出了很多的實(shí)例,是篇非常不錯(cuò)的文章,這里推薦給大家。2014-11-11
nestjs搭建HTTP與WebSocket服務(wù)詳細(xì)過(guò)程
這篇文章主要介紹了nestjs搭建HTTP與WebSocket服務(wù)詳細(xì)過(guò)程的相關(guān)資料,需要的朋友可以參考下2022-11-11
Nestjs自定義注解實(shí)現(xiàn)接口權(quán)限控制詳解
這篇文章主要為大家介紹了Nestjs自定義注解實(shí)現(xiàn)接口權(quán)限控制詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-12-12
node.js中的fs.truncate方法使用說(shuō)明
這篇文章主要介紹了node.js中的fs.truncate方法使用說(shuō)明,本文介紹了fs.truncate的方法說(shuō)明、語(yǔ)法、接收參數(shù)、使用實(shí)例和實(shí)現(xiàn)源碼,需要的朋友可以參考下2014-12-12

