一般来说nginx是不支持静态文件的post请求。会出现如下的错误:


 curl -d 1=1 http://127.0.0.1:8081/test.html

<html>

<head><title>405 Not Allowed</title></head>

<body bgcolor="white">

<center><h1>405 Not Allowed</h1></center>

<hr><center>nginx/0.5.35</center>

</body>

</html>

下面我们就来解决一下这个问题:

1首先需要重新编译nginx 修改/nginx-1.8.0/src/http/modules/ngx_http_static_module.c文件

找到如下字段:


#endif


    if (r->method & NGX_HTTP_POST) {

        return NGX_HTTP_NOT_ALLOWED;

    }



    rc = ngx_http_discard_request_body(r);


    if (rc != NGX_OK) {

        return rc;

    }

我们需要做的是将

if (r->method & NGX_HTTP_POST) {

        return NGX_HTTP_NOT_ALLOWED;

    }

注释掉。。。。

重新编译即可 做到这说明了nginx可以支持静态文件的post的请求了


2.需要在nginx的主配置文件nginx.conf中 log_format 处配置成:


        log_format access '$remote_addr\t$time_local\t`$request_uri`\t$content_length\t$status\t`$http_referer`\t`$http_user_agent`\t$http_x_forwarded_for\t$request_body';说明在日志文件中显示了post-body


3.nginx只有在使用了反向代理端口,它才能在日志文件中记录post-body 。可能只说你们不信。来咱们测试一下:


nginx的子配置文件我的配置如下:

server{


listen 8081;

         location /{

                proxy_pass http://192.168.2.180:82 ;


         if ($time_iso8601 ~ "^(\d{4})-(\d{2})-(\d{2})T(\d{2}):(\d{2}):(\d{2})") {

            set $year $1;

            set $month $2;

            set $day $3;

            set $hour $4;

            set $minutes $5;

           # set $seconds $6;

        }  //此处是配置nginx的日志文件按照分钟切割日志的。只有1.8.0以后的版本才支持在配置文件中配置切割日志

                access_log  /tmp/logs/access-$year-$month-$day-$hour-$minutes.log  access;


}


}

server{

listen 82;

root /tmp/bo ;

access_log /tmp/logs/test.log access ;

}


关于nginx支持静态文件的post请求。需要做一个代理端口,例如80端口代理的是后台服务81端口真正提供服务的端口是81nginx只能在代理端口处能够记录post-body,使用代理端口的好处是能够更好地提高nginx的性能。不会占用太多的资源!!!

 

 

测试如下:我们真正服务的端口是82,代理端口8081

记录82端口的日志是test.log 记录8081端口的日志是bo.log

我们来访问以下代理端口和服务端口:

 

[root@server logs]# curl -d 1=1 http://127.0.0.1:82

this is a test page

[root@server logs]# tail -f test.log 

127.0.0.117/Sep/2015:09:39:59 +0800`/`3200`-``curl/7.19.7 (x86_64-redhat-linux-gnu) libcurl/7.19.7 NSS/3.14.0.0 zlib/1.2.3 libidn/1.18 libssh2/1.4.2`     -  //此处不记录post-body

^C

[root@server logs]# vim /opt/nginx/conf/vhost/bo.conf 

[root@server logs]# curl -d 1=1 http://127.0.0.1:8081

this is a test page

[root@server logs]# tail -f bo.log 

127.0.0.117/Sep/2015:09:52:04 +0800`/`3200`-``curl/7.19.7 (x86_64-redhat-linux-gnu) libcurl/7.19.7 NSS/3.14.0.0 zlib/1.2.3 libidn/1.18 libssh2/1.4.2`     1=1 //此处记录post-body