Socket.io给出欢迎来到socket.io消息

这是我的服务器

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> 

这是我的commaneds

 node server.js 

并在浏览器上我打到URL localhost:80/index.html

点击上面的URL后,我收到消息Welcome to socket.io。

我正在使用nodeJS v0.10.9

       

网上收集的解决方案 "Socket.io给出欢迎来到socket.io消息"

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>