Nginx反向代理405放置Chrome

时间:2018-12-19 14:53:45

标签: google-chrome tomcat put nginx-reverse-proxy http-status-code-405

当我尝试通过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,我可以在配置中添加些什么?

2 个答案:

答案 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;
}