您的位置:首页 > 运维架构 > Nginx

nginx支持静态文件post

2015-09-17 10:22 573 查看
一般来说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端口真正提供服务的端口是81,nginx只能在代理端口处能够记录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
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息