最新消息:雨落星辰是一个专注网站SEO优化、网站SEO诊断、搜索引擎研究、网络营销推广、网站策划运营及站长类的自媒体原创博客

javascript - node.js page refresh calling resources twice? - Stack Overflow

programmeradmin1浏览0评论

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

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

Share Improve this question asked Nov 27, 2011 at 5:16 JesseBueskingJesseBuesking 6,5864 gold badges45 silver badges91 bronze badges 3
  • Does your page contain anything other than text? Any images or anything with a SRC attribute in there? – JohnP Commented Nov 27, 2011 at 5:19
  • No. What I posted is legitimately all that I have. My output is Hi there! hey there!<br /> – JesseBuesking Commented Nov 27, 2011 at 5:21
  • Check your Chrome plugins - I had a sniffer plugin that was making a 2nd http request, every request! – Mike Causer Commented Mar 3, 2013 at 7:38
Add a comment  | 

2 Answers 2

Reset to default 35

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.

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

发布评论

评论列表(0)

  1. 暂无评论