摘要:socket.io用来做实时web程序,解决之前的B/S程序只有无状态连接,特定需求还需要用长连接这种“奇技淫巧”的问题。
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
在浏览器//localhost:8080/就可以使用了,开多个浏览器看效果。
本文由职坐标整理发布,更多相关知识,请关注职坐标WEB前端Node.js频道!
您输入的评论内容中包含违禁敏感词
我知道了
请输入正确的手机号码
请输入正确的验证码
您今天的短信下发次数太多了,明天再试试吧!
我们会在第一时间安排职业规划师联系您!
您也可以联系我们的职业规划师咨询:
版权所有 职坐标-一站式IT培训就业服务领导者 沪ICP备13042190号-4
上海海同信息科技有限公司 Copyright ©2015 www.zhizuobiao.com,All Rights Reserved.
沪公网安备 31011502005948号