Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

node.js page refresh calling resources twice?

I have a basic node.js setup, but I think I'm missing something.

My main.js:

var a = require('./another.js');

var http = require('http');
http.createServer(function (request, response) {
    response.writeHead(200, 
    {
        'Content-Type': 'text/html'
    });

    response.write(a.saysomething('Hi there!') + '<br />');
    response.end();
}).listen(27182);

console.log('Server running at http://127.0.0.1:27182/');

My another.js:

exports.saysomething = function (str) {
    console.log('in saysomething!');
    return str + ' hey there!';
}

The issue is that my console is outputting in saysomething! twice. Am I missing something? When I refresh the page, I expect only one in saysomething!.

like image 901
JesseBuesking Avatar asked Nov 27 '11 05:11

JesseBuesking


2 Answers

Your browser is likely trying to get favicon.ico in addition to the url you are hitting. Try to just do the command on the command line: curl http://127.0.0.1:27182/

Also, you can add logging for request.url. That will show you which urls are being requested.

like image 112
Justin Thomas Avatar answered Sep 23 '22 01:09

Justin Thomas


Here's another way to understand the problem. This node server will track all the requests and show them to you on the browser in JSON. Then you can hit F5 and watch the requests you are making.

    var http = require("http");

    var messages = [];

    http.createServer(function(request, response) {
      console.log("We got a hit @ " + new Date());          
      messages.push(request.url);
      messages.push(request.headers);

      response.writeHead(200, {"Content-Type": "text/plain"});
      for ( var i = 0; i < messages.length; ++i ) {
        response.write("\n\n" + JSON.stringify(messages[i]));
      }
      response.end();
    }).listen(8888);

PS: See also this duplicate for more info nodejs - http.createServer seems to call twice

like image 1
Jess Avatar answered Sep 25 '22 01:09

Jess