这是我的服务器
var io = require('socket.io').listen(80);
io.sockets.on('connection', function (socket) {
socket.emit('news', { hello: 'world' });
socket.on('my other event', function (data) {
console.log(data);
});
});这是我的客户端index.html
<script src="/socket.io/socket.io.js"></script>
<script>
var socket = io.connect('http://localhost:80');
socket.on('news', function (data) {
console.log(data);
socket.emit('my other event', { my: 'data' });
});
</script>以下是我的命令
node server.js在浏览器上,我点击了URL localhost:80/index.html
点击上面的网址后,我收到了欢迎使用socket.io的信息。
我使用的是nodeJS v0.10.9
发布于 2013-06-05 21:09:54
socket.io提供的是socket.io服务器,而不是web服务器。所以socket.io上下文中的index.html并不存在。
相反,您可以使用Express来提供一个基本的web服务器,并结合socket.io来提供消息:
// server.js
var express = require('express');
var app = express();
var server = require('http').createServer(app);
var io = require('socket.io').listen(server);
io.sockets.on('connection', function (socket) {
socket.emit('news', { hello: 'world' });
socket.on('my other event', function (data) {
console.log(data);
});
});
app.use(express.static(__dirname + '/public'));
server.listen(80);// ./public/index.html
<!doctype html>
<html>
<head>
<script src="/socket.io/socket.io.js"></script>
<script>
var socket = io.connect(); // let socket.io autodiscover the server
socket.on('news', function (data) {
console.log(data);
socket.emit('my other event', { my: 'data' });
});
</script>
</head>
<body>
<h1>Hello World</h1>
</body>
</html>https://stackoverflow.com/questions/16939755
复制相似问题