Apache、IIS、Nginx等绝大多数web服务器,都不允许静态文件响应POST请求,否则会返回“HTTP/1.1 405 Method not allowed”错误。


例子:

  • 用curl命令发送POST请求给Nginx服务器上的HTML静态页

[root@new-host ~]# curl -d 1=1 http://www.linuxidc.com/index.html
<!DOCTYPE HTML PUBLIC "-//IETF//DTD HTML 2.0//EN">
<HTML><HEAD>
<TITLE>405 Method Not Allowed</TITLE>
</HEAD><BODY>
<H1>Method Not Allowed</H1>
The requested method POST is not allowed for the URL /index.html.<P>
<HR>
<ADDRESS>Apache/1.3.37 Server at www.linuxidc.com Port 80</ADDRESS>
</BODY></HTML>

  • 用curl命令发送POST请求给Nginx服务器上的HTML静态页

[root@new-host ~]# curl -d 1=1 http://www.linuxidc.com/index.htm
<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>


解决方法:

有些应用中需要使静态文件能够响应POST请求。

对于Nginx,可以修改nginc.conf配置文件,改变“405错误”为“200 ok”,并配置location来解决,方法如下:

方法一:

##在nginx配置中添加error_page 405 =200  $request_uri;这句即可。
server {
listen 8080;
server_name localhost;
access_log off;
location / {
alias /data/apps/qsh-web/;
index index.html index.htm;
error_page 405 =200 $request_uri;
try_files $uri $uri/ /index.html;
}

}

方法二:

upstream local-web {    
server 10.0.1.100:80;
}
server
{
listen 80;
server_name www.linuxidc.com;
index index.html index.htm index.php;
root /opt/htdocs;
if (-d $request_filename)
{
rewrite ^/(.*)([^/])$ http://$host/$1$2/ permanent;
}
location / {
try_files $uri @test.mobile;
}
error_page 405 =200 @405;
location @405
{
proxy_method GET,POST;
proxy_pass http://local-web/$request_uri;
}
location @test.mobile {
if ($request_uri = /){
#return 200 $request_uri;
rewrite ^(.*)$ /index.html last;
}
include proxy_parameter.conf;
proxy_pass http://172.17.17.3:3031;
}
location ~* \.(gif|jpg|jpeg|png|css|js|ico|html)$ {
#return 300 $request_uri;
gzip on;
gzip_http_version 1.0;
gzip_types application/javascript text/css image/jpeg;
proxy_set_header Accept-Encoding 'gzip';
add_header X-Frame-Options 'SAMEORIGIN';
add_header abc '132';
root /data/html5_test/dist/;
index index.html;
}
location ~* \.(eot|ttf|ttc|otf|eot|woff|woff2|svg)$ {
add_header Access-Control-Allow-Origin *;
root /data/html5_test/dist/;
index index.html;
}
}