javascript - Node.js - 将响应状态代码记录到控制台(一个 Django 开发服务器)

标签 javascript node.js

我正在尝试构建一个带有类似于 Django 开发服务器的控制台日志记录的 Node.js 服务器。例如

[27/Jun/2011 15:26:50] "GET /?test=5 HTTP/1.1" 200 545

以下 server.js(基于 Node Beginner Book tutorial)获取时间和请求信息:

var http = require("http");
var url = require ("url");
var port = 1234;

function start(route, handle) {
    function onRequest(request, response) {
        var pathname = url.parse(request.url).pathname;
        var query = url.parse(request.url).query;
        route(handle, pathname, query, response);
        logRequest(request);
    }
    http.createServer(onRequest).listen(port);
    console.log("\nServer running at http://192.168.1.5:" + port + "/");
    console.log("Press CONTROL-C to quit.\n");
}

function logRequest(request) {
    var pathname = url.parse(request.url).pathname;
    var query = url.parse(request.url).query;
    if (query == undefined) {
        query = "";
    }
    var currentDate = new Date();
    var day = currentDate.getDate();
    var month = currentDate.getMonth() + 1;
    var year = currentDate.getFullYear();
    var hours = currentDate.getHours();
    var minutes = currentDate.getMinutes();
    var seconds = currentDate.getSeconds();
    if (minutes < 10) {
        minutes = "0" + minutes;
    }
    if (seconds < 10) {
        seconds = "0" + seconds;
    }
    console.log("[" + year + "/" + month + "/" + day + 
                " " + hours + ":" + minutes + ":" + seconds + '] "' +
                request.method + " " + pathname + query +
                " HTTP/" + request.httpVersion + '"');
}    

exports.start = start;

问题:我将如何更新此代码以获取 response.statusCode 以及日志输出中的任何“545”数字?

当我尝试将响应对象添加到 logRequest 函数时,响应 statusCode 始终为“200”,即使我知道(通过调试日志记录)我的 router.js 正在生成 404 错误。

最佳答案

如果您使用的是在您链接的教程中找到的路由方法,那么使用 response.statusCode 不起作用的原因是因为他们使用此行设置了 404 状态代码

response.writeHead(404, {"Content-Type": "text/html"});

如果您查看那里的文档 Node.JS Docs - writeHead它声明 .writeHead 不会设置 .statusCode 值。如果您想使用 .statusCode 值,您应该将 route 方法中的行更改为如下所示:

response.statusCode = 404;
response.setHeader("Content-Type", "text/html");

直接为 statusCode 赋值并使用“隐式” header 声明(setHeader 而不是 writeHead)将为用户产生相同的结果,但在您这边,稍后您将可以在日志方法中访问 statusCode。

关于javascript - Node.js - 将响应状态代码记录到控制台(一个 Django 开发服务器),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6498685/

相关文章:

javascript - 如何在 JQuery 中通过属性查找元素?

javascript - FireFox 中的客户端高度

javascript - 从表单中删除节点?

javascript - 一次将单个对象导出到 JSON 文件中的对象数组

node.js - 为什么脚本完成后node.js服务器不退出?

node.js - Node Js 是否使用 libuv 线程池进行网络 I/O

java - Selenium Standalone 已退出,代码为 1/系统找不到指定的路径

Javascript 错误 - 左位移返回错误的输出

http - 如何很好地销毁 Node.js http.request 连接?

javascript - Webpack 无法呈现快速导入