0

我正在寻找解决方案,以监控 http response.write 方法的发送/写入过程。

当事件(在我的情况下是带有安全令牌的第二个请求)出现(或不出现)时,我希望能够监视和停止正在运行的进程。

这通常是可能的吗,如果是这样,是否有人对我有一些和平的代码?

这是代码行的咖啡片段

if req.headers.range?
    console.log "serve range request from cache"
    # browser wants chunged transmission
    range = req.headers.range
    parts = range.replace(/bytes=/, "").split "-"
    partialstart = parts[0]
    partialend = parts[1]
    total = file.length
    start = parseInt partialstart, 10
    end = if partialend then parseInt partialend, 10 else total - 1

    header["Content-Range"] = "bytes #{start}-#{end}/#{total}"
    header["Accept-Ranges"] = "bytes"
    header["Content-Length"]= (end-start)+1
    header['Transfer-Encoding'] = 'chunked'
    header["Connection"] = "close"

    res.writeHead 206, header
    # yeah I dont know why i have to append the '0'
    # but chrome wont work unless i do
    res.write file.slice(start, end)+'0', "binary"
  else
    console.log "serve normal request from cache"
    # reply to normal un-chunked request
    res.writeHead 200, header
    res.write file, "binary"
    console.log err if err
  res.end()

有没有办法将res.write 文件,“二进制”行包装在某种函数或进程中,可以被杀死?

亲切的问候

4

1 回答 1

1

当然。您可以执行以下操作:

origWrite = res.write

res.write = function(buffer, encoding) {
    // do some monitoring, starting, stopping, whatever you like
    retval = origWrite(buffer, encoding);
    // do some more monitoring, starting, stopping, whatever you like
    return retval;
}

将此代码放在 Express 堆栈顶部的中间件中,这样您就可以监控来自所有中间件的所有写入,而不仅仅是您自己的。

另一件事:

在您的代码中,您指定Content-Lengthand Transfer-Encoding: chunked。两个不在一起。这chunked就是为什么 Chrome(和任何其他浏览器......)想要0最后的原因:分块编码来自“块”,每个块都以其长度的 ASCII 十六进制表示开始。事物以一个空块结束(即:一个没有数据的长度为 0 的块)。之后您还应该添加一个 CR-LF。

于 2013-09-17T11:52:05.813 回答