Search code examples
javascriptnode.jscometsocket.io

NodeJS + socket.io: simple Client/Server example not working


I’m using NodeJS v0.4.8 and the latest Version of socket.io from

npm install socket.io

on Ubuntu:

Linux mars 2.6.38-8-generic #42-Ubuntu SMP Mon Apr 11 03:31:50 UTC 2011 i686 i686 i386 GNU/Linux

The following code unfortunately doesn't produce any output, wheter on client, nor on server side.

Does anybody have a clue?

SERVER-SIDE

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"); }) ;
}); 

CLIENT-SIDE

<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>

The output from NodeJS (NOT the sys.puts("...") calls) is:

info - socket.io started debug - served static /socket.io.js debug - client authorized info - handshake authorized info - handshaken b61a5c2751c1c8c8493db4b79d19e779


Solution

  • I also(like Derrish) like to use express framework to simplify my work(AWESOME :)). You can download and extract this sample from http://dl.dropbox.com/u/314941/socketio.zip. I believe you don't even have to install these modules because I have bundled them locally(just run) thanks to npm :).

    How to install:

    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
    

    The code:

    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 () {
      });
    });
    

    public/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> 
    

    Listing of my modules:

    alfred@alfred-laptop:~/tmp/socketio$ npm ls
    /home/alfred/tmp/socketio
    ├─┬ [email protected] 
    │ ├── [email protected] 
    │ ├── [email protected] 
    │ └── [email protected] 
    └── [email protected]
    

    Installed modules(NOT necessary):

    npm install express
    npm install socket.io
    

    Browser will display:

    1. socket.io on start, but probably you can't see this because it will be replaced with connected.
    2. connected when the user connects to socket.io.
    3. After 2 seconds it will display Waited two seconds!image