使用Node.js的socket.io模塊開發實時web程序


首發:個人博客,更新&糾錯&回復

今天的思維漫游如下:從.net的windows程序開發,摸到nodejs的桌面程序開發,又熟悉了一下nodejs,對“異步”的理解有了上上周對操作系統的學習而更能理解。
然后發現了Node.js中的socket.io這個模塊,又覺得跟前幾天用.net做客戶端的socket游戲了。
技術世界,兜兜轉轉,相逢一笑,疑是故人。

socket.io用來做實時web程序,解決之前的B/S程序只有無狀態連接,特定需求還需要用長連接這種“奇技淫巧”的問題。
當然,這是html5中websocket技術的任務,而socket.io正是封裝了它。
socket.io的文檔在這里,先寫個demo,明天想個好玩的點子玩玩看。
真的好短好舒服,比java的socket編程美觀,比java的websocket服務端編程美觀到不知哪里去了。

服務器代碼:

var app = require("http").createServer(handler);
var io = require("socket.io").listen(app);
var fs = require("fs");
var html = fs.readFileSync("index.html", "utf8");

function handler(req, res){
    res.setHeader("Content-Type", "text/html");
    res.setHeader("Content-Length", Buffer.byteLength(html, "utf8"));
    res.end(html);
}

app.listen(8080);

io.sockets.on("connection", function(socket){
    //從客戶端獲得命令
    socket.on("say", function(data){
        //向客戶端發命令
        io.sockets.send(data.content);
    });
});

網頁代碼:

<!DOCTYPE html>
<html>
<head>
    <meta charset="utf8">
</head>
<body>
    <div id="msg"></div>
    <input type="text" id="t"/>
    <input type="button" id="b" value="發送"/>

    <script type="text/javascript" src="/socket.io/socket.io.js"></script>
    <script type="text/javascript">
        var socket = io.connect();
        //從服務器獲得消息
        socket.on("message", function(msg){
            var newMsg = document.createElement("div");
            newMsg.innerHTML = msg;
            document.getElementById("msg").appendChild(newMsg);
        });
        
        document.getElementById("b").onclick = function(){
            var txt = document.getElementById("t").value;
            //向服務器發消息
            socket.emit("say", {
                "content" : txt
            });
        }
    </script>
</body>
</html>

用法:在已安裝nodejs的前提下,在某個文件夾執行

npm install socket.io

再新建main.js和index.html倆文件,代碼分別如上,然后啟動服務器

node main.js 

在瀏覽器http://localhost:8080/就可以使用了,開多個瀏覽器看效果。

小貼士:
按shift在文件夾里右鍵單擊,會彈出“在此處打開命令行窗口”的菜單項,比windows+r,再cmd,再復制文件夾路徑,再cd過去方便多了。

長期歡迎項目合作機會介紹,項目收入10%用於酬謝介紹人。新浪微博: @冷鏡,QQ: 908789432


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM