NodeJS + socket.io: простой пример клиент / сервер не работает
Я использую NodeJS v0.4.8 и последнюю версию socket.io от
npm установить socket.io
на Ubuntu:
Linux mars 2.6.38-8-generiC#42-Ubuntu SMP Пн 11 апреля 03:31:50 UTC 2011 i686 i686 i386 GNU/Linux
Следующий код, к сожалению, не выдает ни вывода, ни клиента, ни сервера.
У кого-нибудь есть подсказка?
Серверный
var http = require('http'),
io = require('socket.io'),
fs = require('fs'),
sys = require('sys');
respcont = fs.readFileSync('testclient.js');
server = http.createServer(function(req, res){
res.writeHead(200, {'Content-Type': 'text/html'});
res.end(respcont);
});
server.listen(8082);
var socket = io.listen(server);
socket.on('connection', function(client){
sys.puts("New client is here!");
client.send("hello world");
client.on('message', function(msg) { sys.puts("client has sent:"+msg); }) ;
client.on('disconnect', function() { sys.puts("Client has disconnected"); }) ;
});
СТОРОНА КЛИЕНТА
<html>
<body>
<script type="text/javascript" src="http://localhost:8082/socket.io/socket.io.js"></script>
<script>
var socket = new io.Socket(null,{port:8082,rememberTransport:true,timeout:1500});
socket.connect();
socket.on('connect', function() {
console.log('connected to server');
socket.send('Hi Server...');
});
socket.on('message', function() {
console.log('received a message!');
});
socket.on('disconnect', function() {
console.log('disconnected from server');
});
</script>
</body>
</html>
Выходные данные NodeJS (НЕ вызовы sys.puts("...")):
info - socket.io начал отладку - обслужен static /socket.io.js debug - информация о клиенте авторизована - информация о авторизации рукопожатия - handshaken b61a5c2751c1c8c8493db4b79d19e779
3 ответа
Мне также (как и Derrish) нравится использовать Express Framework для упрощения моей работы (УДИВИТЕЛЬНЫЙ:)). Вы можете скачать и извлечь этот образец с http://dl.dropbox.com/u/314941/socketio.zip. Я считаю, что вам даже не нужно устанавливать эти модули, потому что я связал их локально (просто запустил) благодаря npm:).
Как установить:
alfred@alfred-laptop:~/tmp/socketio$ uname -a
Linux alfred-laptop 2.6.35-28-generic #50-Ubuntu SMP Fri Mar 18 19:00:26 UTC 2011 i686 GNU/Linux
alfred@alfred-laptop:~/tmp$ wget http://dl.dropbox.com/u/314941/socketio.zip
alfred@alfred-laptop:~/tmp$ unzip socketio.zip
alfred@alfred-laptop:~/tmp$ cd socketio/
alfred@alfred-laptop:~/tmp/socketio$ node -v
v0.4.7
alfred@alfred-laptop:~/tmp/socketio$ npm -v
1.0.6
alfred@alfred-laptop:~/tmp/socketio$ node app.js
Код:
app.js:
// npm install express
// npm install socket.io
var sys = require('sys'),
express = require('express'),
app = express.createServer('127.0.0.1'),
io = require('socket.io');
app.use(express.static(__dirname + '/public'));
app.get('/', function (req, res) {
res.send('Hello World');
});
app.listen(3000);
var socket = io.listen(app);
socket.on('connection', function (client){
// new client is here!
setTimeout(function () {
client.send('Waited two seconds!');
}, 2000);
client.on('message', function () {
}) ;
client.on('disconnect', function () {
});
});
общественности / index.html:
<html>
<p id="text">socket.io</p>
<script src="socket.io/socket.io.js"></script>
<script src="jquery-1.6.1.min.js"></script><!-- Downloaded Jquery -->
<script>
$(document).ready(function(){
var socket = new io.Socket(),
text = $('#text');
socket.connect();
socket.on('connect', function () {
text.html('connected');
});
socket.on('message', function (msg) {
text.html(msg);
});
socket.on('disconnect', function () {
text.html('disconnected');
});
});
</script>
Список моих модулей:
alfred@alfred-laptop:~/tmp/socketio$ npm ls
/home/alfred/tmp/socketio
├─┬ express@2.3.11
│ ├── connect@1.4.6
│ ├── mime@1.2.2
│ └── qs@0.1.0
└── socket.io@0.6.18
Установленные модули (НЕ обязательно):
npm install express
npm install socket.io
Браузер отобразит:
socket.io
в начале, но, вероятно, вы не можете увидеть это, потому что он будет заменен наconnected
,connected
когда пользователь подключается к socket.io.- Через 2 секунды отобразится
Waited two seconds!
Экспресс 3.0 + рабочий пример Socket.io
сервер ( app.js)
var express = require('express');
var app = express.createServer();
var socket = require('socket.io');
app.configure(function(){
app.use(express.static(__dirname + '/'));
});
var server = app.listen(8081);
var io = socket.listen(server);
io.sockets.on('connection', function (socket) {
console.log("connnect");
socket.on('disconnect', function (socket) {
console.log("disconnect");
});
});
клиент ( index.html)
<script src="/socket.io/socket.io.js"></script>
<script>
var socket = io.connect('http://localhost:8081');
</script>
Вы можете раскошелиться на код, используя ссылку ниже https://github.com/sreekumar-kr/Expree3.0---Socket.IO
Я взял ваш пример и поместил его в приложение для узлов с помощью Express. Ваш HTML-код был размещен в статическом HTML-файле в публичном. Ваш пример работал нормально. Код показан ниже. Я хотел убедиться, что файл сценария socket.io и файл HTML обслуживаются правильно.
var http = require('http'),
io = require('socket.io'),
express = require('express');
var app = module.exports = express.createServer();
// Configuration
app.configure(function(){
app.set('views', __dirname + '/views');
app.set('view engine', 'jade');
app.use(express.bodyParser());
app.use(express.methodOverride());
app.use(app.router);
app.use(express.static(__dirname + '/public'));
});
if (!module.parent) {
app.listen(9000);
console.log("server started at %s", (new Date()).toUTCString());
console.log("listening on port %d", app.address().port);
}
// socket.io
var socket = io.listen(app);
socket.on('connection', function(client){
console.log("New client is here!");
client.send("hello world");
client.on('message', function(msg){ console.log("client has sent:"+msg); }) ;
client.on('disconnect', function(){ console.log("Client has disconnected"); }) ;
client.on('disconnect', function(){ })
});