基于Node.js和Cocos Creator的開發(fā)【五,實(shí)現(xiàn)Socket通信】

一憔维,后端的實(shí)現(xiàn)

后端安裝nodejs-websocket模塊眠菇,在命令行中輸入以下命令:
npm install nodejs-websocket
即可完成nodejs-websocket的安裝。
在httpServer.js中輸入以下代碼:

var ws = require('nodejs-websocket');

var server = ws.createServer(function (conn) {
    //處理消息
    conn.on('text', function (str) {
        conn.sendText('from server..');
    })
 
    conn.on("close", function (code, reason) {
        console.log("關(guān)閉連接");
    })
    conn.on("error", function (code, reason) {
        console.log("異常關(guān)閉");
    });
}).listen(8183);

至此慈缔,我們實(shí)現(xiàn)了在8183端口上的socket服務(wù)器功能叮称。

二,前端的實(shí)現(xiàn)

Cocos Creator中藐鹤,支持 Web 平臺(tái)上最廣泛使用的標(biāo)準(zhǔn)網(wǎng)絡(luò)接口:

  • XMLHttpRequest:用于短連接
  • WebSocket:用于長(zhǎng)連接
    在assets/Script/net目錄下新建socket.js瓤檐,輸入以下代碼:
var socket = cc.Class({
    ctor: function() {
        var ws = new WebSocket('ws://127.0.0.1:8183/');
        // 發(fā)起連接
        ws.onopen = function (event) {
            console.log("ws test 000 Send Text WS was opened.");
            ws.send('send text to server ...');
        };
        ws.onmessage = function (event) {
            console.log("ws test 001 response text msg: " + event.data);
        };
        ws.onerror = function (event) {
            console.log("ws test 002 Send Text fired an error");
        };
        ws.onclose = function (event) {
            console.log("ws test 003 WebSocket instance closed.");
        };

        this._ws = ws;
    }
});

module.exports = socket;

三,測(cè)試

在HelloWorld.js中引入模塊:
var socket = require('socket');
在onLoad函數(shù)中加入以下一行代碼:
var s = new socket();
即可測(cè)試前端和后端的連接娱节。


代碼在這兒

上一篇 實(shí)現(xiàn)用戶登錄

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末挠蛉,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子肄满,更是在濱河造成了極大的恐慌谴古,老刑警劉巖,帶你破解...
    沈念sama閱讀 212,816評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件稠歉,死亡現(xiàn)場(chǎng)離奇詭異掰担,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)怒炸,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,729評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門带饱,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人横媚,你說我怎么就攤上這事纠炮≡绿耍” “怎么了灯蝴?”我有些...
    開封第一講書人閱讀 158,300評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵恢口,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我穷躁,道長(zhǎng)耕肩,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,780評(píng)論 1 285
  • 正文 為了忘掉前任问潭,我火速辦了婚禮猿诸,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘狡忙。我一直安慰自己梳虽,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,890評(píng)論 6 385
  • 文/花漫 我一把揭開白布灾茁。 她就那樣靜靜地躺著窜觉,像睡著了一般。 火紅的嫁衣襯著肌膚如雪北专。 梳的紋絲不亂的頭發(fā)上禀挫,一...
    開封第一講書人閱讀 50,084評(píng)論 1 291
  • 那天,我揣著相機(jī)與錄音拓颓,去河邊找鬼语婴。 笑死,一個(gè)胖子當(dāng)著我的面吹牛驶睦,可吹牛的內(nèi)容都是我干的砰左。 我是一名探鬼主播,決...
    沈念sama閱讀 39,151評(píng)論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼场航,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼缠导!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起旗闽,我...
    開封第一講書人閱讀 37,912評(píng)論 0 268
  • 序言:老撾萬榮一對(duì)情侶失蹤酬核,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后适室,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體嫡意,經(jīng)...
    沈念sama閱讀 44,355評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,666評(píng)論 2 327
  • 正文 我和宋清朗相戀三年捣辆,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了蔬螟。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,809評(píng)論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡汽畴,死狀恐怖旧巾,靈堂內(nèi)的尸體忽然破棺而出耸序,到底是詐尸還是另有隱情,我是刑警寧澤鲁猩,帶...
    沈念sama閱讀 34,504評(píng)論 4 334
  • 正文 年R本政府宣布坎怪,位于F島的核電站,受9級(jí)特大地震影響廓握,放射性物質(zhì)發(fā)生泄漏搅窿。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 40,150評(píng)論 3 317
  • 文/蒙蒙 一隙券、第九天 我趴在偏房一處隱蔽的房頂上張望男应。 院中可真熱鬧,春花似錦娱仔、人聲如沸沐飘。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,882評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)耐朴。三九已至,卻和暖如春恩溅,著一層夾襖步出監(jiān)牢的瞬間隔箍,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,121評(píng)論 1 267
  • 我被黑心中介騙來泰國(guó)打工脚乡, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留蜒滩,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 46,628評(píng)論 2 362
  • 正文 我出身青樓奶稠,卻偏偏與公主長(zhǎng)得像俯艰,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子锌订,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,724評(píng)論 2 351

推薦閱讀更多精彩內(nèi)容