【发布时间】:2014-12-16 08:11:02
【问题描述】:
我正在通过一本书(学习节点)中的以下代码学习 NodeJS 和 Socket.IO。这个例子奏效了。但我想知道节点是如何为statment <script src="/socket.io/socket.io.js"></script> 中的 socket.io.js 文件提供服务的,因为项目根目录中没有名为 socket.io 的文件夹,我也没有写入服务器静态文件的代码。这是通过 Socket.IO 模块完成的吗?使用 express 服务静态文件会不会冲突?
客户端代码
<html lang="en">
<head>
<meta charset="utf-8">
<title>bi-directional communication</title>
<script src="/socket.io/socket.io.js"></script>
<script>
var socket = io.connect('http://localhost:8124');
socket.on('news', function (data) {
var html = '<p>' + data.news + '</p>';
document.getElementById("output").innerHTML=html;
socket.emit('echo', { back: data.news });
});
</script>
</head>
<body>
<div id="output"></div>
</body>
</html>
服务器端代码
var app = require('http').createServer(handler)
, io = require('socket.io').listen(app)
, fs = require('fs')
var counter;
app.listen(8124);
function handler (req, res) {
fs.readFile(__dirname + '/index.html',
function (err, data) {
if (err) {
res.writeHead(500);
return res.end('Error loading index.html');
}
counter = 1;
res.writeHead(200);
res.end(data);
});
}
io.sockets.on('connection', function (socket) {
socket.emit('news', { news: 'world' });
socket.on('echo', function (data) {
if (counter <= 50) {
counter++;
console.log(data.back);
socket.emit('news', {news: data.back});
}
});
});
【问题讨论】:
-
虚拟路径。基本上,服务器端库处理以“/socket.io/”开头的请求并输出资源。实际文件在其他地方。
标签: javascript node.js express socket.io