首發:我的博客,更新&糾錯&回覆javascript
今天的思惟漫遊以下:從.net的windows程序開發,摸到nodejs的桌面程序開發,又熟悉了一下nodejs,對「異步」的理解有了上上週對操做系統的學習而更能理解。
而後發現了Node.js中的socket.io這個模塊,又以爲跟前幾天用.net作客戶端的socket遊戲了。
技術世界,兜兜轉轉,相逢一笑,疑是故人。html
socket.io用來作實時web程序,解決以前的B/S程序只有無狀態鏈接,特定需求還須要用長鏈接這種「奇技淫巧」的問題。
固然,這是html5中websocket技術的任務,而socket.io正是封裝了它。
socket.io的文檔在這裏,先寫個demo,明天想個好玩的點子玩玩看。
真的好短好舒服,比java的socket編程美觀,比java的websocket服務端編程美觀到不知哪裏去了。html5
服務器代碼:java
var app = require("http").createServer(handler);
var io = require("socket.io").listen(app);
var fs = require("fs");
var html = fs.readFileSync("index.html", "utf8");nodefunction handler(req, res){
res.setHeader("Content-Type", "text/html");
res.setHeader("Content-Length", Buffer.byteLength(html, "utf8"));
res.end(html);
}webapp.listen(8080);npm
io.sockets.on("connection", function(socket){
//從客戶端得到命令
socket.on("say", function(data){
//向客戶端發命令
io.sockets.send(data.content);
});
});編程
網頁代碼:windows
<!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過去方便多了。