nginx header 와 body 를 우아 하 게 인쇄 하 는 방법

3726 단어
장면
레 퍼 런 스https://segmentfault.com/a/1190000000606867response 의 신문 문 체 를 얻 을 수 있 습 니 다. 업무 테스트 에서 응답 헤더 나 응답 체 바디 를 얻 는 수요 가 있 기 때문에 여 기 는 header_filter_by_lua 을 통 해 응답 메시지 헤드 를 변수 에 배분 하여 이 루어 집 니 다.
nginx 설정
worker_processes  1;
error_log logs/error.log;
events {
    worker_connections 1024;
}
http {
    log_format log_req_resp '$remote_addr - $remote_user [$time_local] '
        '"$request" $status $body_bytes_sent '
        '"$http_referer" "$http_user_agent" $request_time req_body:"$request_body"' 
        ' resp_body:"$resp_body" resp_header:"$resp_header"';

    server {
        listen 8082;
        access_log logs/access.log log_req_resp;

        set $resp_header "";
        header_filter_by_lua '
            local h = ngx.resp.get_headers()
            for k, v in pairs(h) do
            ngx.var.resp_header=ngx.var.resp_header..k..": "..v
            end
        ';

        lua_need_request_body on;

        set $resp_body "";
        body_filter_by_lua '
            local resp_body = string.sub(ngx.arg[1], 1, 1000)
            ngx.ctx.buffered = (ngx.ctx.buffered or "") .. resp_body
            if ngx.arg[2] then
                ngx.var.resp_body = ngx.ctx.buffered
            end
        ';

        location / {
            echo "Hello World!";
        }
    }
}

그리고 access 로그 에 있 습 니 다.
다음으로 전송:https://www.cnblogs.com/sunsky303/p/9114813.html

좋은 웹페이지 즐겨찾기