nginx lua 获取响应体

我需要获取响应体,例如从网址获取的响应 HTML 代码,使用以下代码。

location /configure/result.php {

  log_by_lua_block  {
    ngx.log(ngx.ERR, "REQUEST capturing started")

    json = require "json"

    function getval(v, def)
      if v == nil then
         return def
      end
      return v
    end

    local data = {
      request={},
      response={}
    }
    local req = data.request
    local resp = data.response

    req["host"] = ngx.var.host
    req["uri"] = ngx.var.uri
    req["headers"] = ngx.req.get_headers()
    req["time"] = ngx.req.start_time()
    req["method"] = ngx.req.get_method()
    req["get_args"] = ngx.req.get_uri_args()
    req["post_args"] = ngx.req.get_post_args()
    req["body"] = ngx.var.request_body

    content_type = getval(ngx.var.CONTENT_TYPE, "")

    resp["headers"] = ngx.resp.get_headers()
    resp["status"] = ngx.status
    resp["duration"] = ngx.var.upstream_response_time
    resp["time"] = ngx.now()
    resp["body"] = ngx.var.response_body -- 这里有问题

    ngx.log(ngx.CRIT, json.encode(data));
  }
}

但它不记录接收到的响应数据,例如从该网址获取的处理后的源代码,我怎样才能获取响应数据?

我的想法是获取响应数据,然后使用正则表达式从源代码中读取特定值,然后进行 x-y

点赞
用户7121513
用户7121513

我现在不能测试,但也许在请求处理的日志阶段期间,响应是无法访问的?

您可以使用'ngx.ctx'表在body_filter_by_lua_block中尝试获取响应数据:

    body_filter_by_lua_block {
        ngx.ctx.response_body = ngx.arg [1]
    }

然后在log_by_lua_block块中使用它:

    log_by_lua_block {
        ...
        resp [“body”] = ngx.ctx.response_body
        ngx.log(ngx.CRIT, json.encode(data))
    }

(请注意,这只是一个猜测,请告诉我是否有效)

2019-01-30 01:37:05