当我尝试通过Nginx反向代理请求Tomcat服务器时,收到405响应。
如果我直接请求tomcat服务器,则它可以从Chrome或Firefox成功运行。但是,如果我请求Nginx代理服务器,我会从Chrome获得405,但可以从Firefox运行。
我一直在Nginx.conf中使用不同的配置进行测试 location / foo / {...}
我尝试过:
error_page 405 =200 $uri;
也
add_header "Allow" "GET, POST, HEAD, PUT, DELETE" always;
add_header "Access-Control-Allow-Methods" "GET, POST, PUT, DELETE, OPTIONS" always;`
location / {
dav_methods PUT DELETE;
proxy_pass http://csprocure;
}
我用于重定向的nginx.conf如下:
upstream serverS {
server xxx.xxx.xxx.xxx:yyyy;
}
server {
listen 80;
server_name $hostname;
access_log /var/log/nginx/access.log;
error_log /var/log/nginx/error.log;
error_log /dev/stdout info;
access_log /dev/stdout;
location /foo/ {
proxy_pass http://serverS;
proxy_redirect http://xxx.xxx.xxx.xxx/ http://xxx.xxx.xxx.xxx:yyyy/;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Host $server_name;
proxy_set_header X-Forwarded-Proto: https;
}
要避免在Chrome中使用405,我可以在配置中添加些什么?
答案 0 :(得分:0)
可以在线找到关于将HTTP方法列入白名单的很好的解释here
这对我有用:
add_header Allow "GET, POST, HEAD, PUT, DELETE" always;
if ( $request_method !~ ^(GET|POST|HEAD|PUT|DELETE)$ ) {
return 405;
}
..显然,确保在测试更改之前检查配置nginx -t
并重新加载配置nginx -s reload
答案 1 :(得分:0)
我一直在比较Firefox和Chrome之间的请求,但Chrome方面有所不同,在请求Chrome中,标头请求中添加了一个“ Origin”参数,这会导致错误。
因此,在我的nginx.conf中,我添加了避免在location /
下使用的参数proxy_set_header Origin "";
所以我现在的位置配置块是:
location /foo/ {
proxy_set_header Origin "";
proxy_pass http://serverS;
proxy_redirect http://xxx.xxx.xxx.xxx/ http://xxx.xxx.xxx.xxx:yyyy/;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Host $server_name;
proxy_set_header X-Forwarded-Proto: https;
}