我正在节点服务器上创建资源并将 ETag 附加到每个资源。我正在使用这个问题中找到的方法我应该使用什么编码在nodeJS中正确生成带有加密的ETag?用于生成 ETag。但是,当我HEAD
使用 curl 在命令行上发出请求时,例如:
$ curl -i -u username:password -X HEAD http://localhost:3000/aResource/0
答案是
HTTP/1.1 200 OK
X-Powered-By: Express
ETag: "1a37c148692f92ad6c97887f77c873e6"
Content-Type: text/plain
Date: Sat, 26 Oct 2013 01:06:28 GMT
Connection: keep-alive
^C
$
我必须专门按下Control-C
才能再次看到命令提示符。另一方面,我觉得这很奇怪,因为我处理HEAD
请求的方式是通过节点上的 app.head 并在身份验证之后调用该函数:
function serveResourceEtag(req, res) {
console.log("Following route through HEAD");
var anID = parseInt(req.params[resourceID], "utf8");
if (anID < serverData.resourceEtags.length) {
res.writeHead (200, {"ETag": "\"" + serverData.resourceEtags[anID] + "\"", "Content-Type": "text/plain"});
res.end();
}
else {
res.writeHead (404, {"Content-Type": "text/plain"});
res.end();
}
};
换句话说,即使我有 res.end(); 命令到底,传送不知为何没有停止。据我了解,HEAD
请求应获得与请求相同的标头GET
。与 a 的区别GET
在于,在HEAD
我们没有GET
请求正文的情况下。你能告诉这里似乎是什么问题吗?