Node.js的expressjs框架对response的处理流程实验

来源:互联网 发布:电脑报淘宝店怎么样 编辑:程序博客网 时间:2024/04/30 16:53

之前一直考虑实现这么个流程:

  1. 获取用户更新数据的请求
  2. 更新缓存
  3. 返回结果
  4. 数据持久化

主要是不想让数据持久化这一步占用响应时间,实验的代码如下

app.get('/', function (req, res, next) {    res.status(200).jsonp({ data: "AAA" })    next()}, function (req, res) {    setTimeout(function () {        console.log("Cached!");    }, 5000)});

这里我们用了express的中间件,可以把数据处理的各个流程写到不同的function里面,根据需要组装。用POSTMAN测试一下,你会看到瞬间返回了“AAA”,然后过了5秒钟才在console打出了”Cached“,这基本就是我想要的结果。

然后继续实验,把

res.status(200).jsonp({ data: "AAA" })

改成

return res.status(200).jsonp({ data: "AAA" })

这次客户端正常返回,但是console没有打印出”Cached“,也就是说加了return之后直接结束了整个响应流程,后面的所有代码和中间件都不再执行了。

我们继续改造:

app.get('/', function (req, res, next) {    res.status(200).jsonp({ data: "AAA" })    next()}, function (req, res) {    res.status(200).jsonp({ data: "BBB" })    setTimeout(function () {        console.log("Cached!");    }, 5000)});

那如果我多次修改response对象会怎么样呢?
这次客户端也收到结果了,但是console却直接打印了Error:Cannot set header after they are sent.
由此我们可见res之后响应就直接发给客户端了。

0 0
原创粉丝点击