gpt4 book ai didi

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

转载 作者:搜寻专家 更新时间:2023-10-31 23:33:43 25 4
gpt4 key购买 nike

我正在尝试构建一个带有类似于 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/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com