nginx代理无法使用子域

时间:2018-12-06 13:55:24

标签: nginx proxy

我有两个域

alpha.mydomain.com api-alpha.mydomain.com

我正在尝试使用nginx作为代理

我遇到错误

  

访问“ https://api-alpha.mydomain.com/dup-check”处的XMLHttpRequest   来自来源“ https://alpha.mydomain.com”的信息已被CORS阻止   策略:对预检请求的响应未通过访问控制   检查:标题上没有'Access-Control-Allow-Origin'标头   请求的资源。

我会根据自己的设置认为,该请求不应使用 api-alpha.mydomain.com ,而应使用127.0.0.1(并且不会收到CORS错误)

注意::我正在使用cloudflare https,所以控制台错误是cloudflare是SSL的https,并与我的nginx服务器的端口80通讯

这是我的nginx配置的一部分

   server {
        listen        80;
        server_name   alpha.mydomain.com ;

        access_log   /var/log/nginx.access_log  main;

        root /home/mydomain/react-front/dist;

        location / {
            try_files $uri $uri/ /index.html;
        }

    }
   server {
        listen        80;
        server_name   api-alpha.mydomain.com ;

        access_log   /var/log/nginx-api-alpha-access.log  main;

        location /{
                proxy_pass         http://127.0.0.1:4001/;
                proxy_set_header X-Real-IP $remote_addr;
                proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
                proxy_set_header X-NginX-Proxy true;
                proxy_ssl_session_reuse off;
                proxy_set_header Host $http_host;
                proxy_redirect off;
        }

    }

这是nginx-api-alpha-access.log

中的条目
  

“ OPTIONS / dup-check HTTP / 1.1” 502 750“-”“ Mozilla / 5.0(Macintosh; Intel Mac OS X 10_14_1)AppleWebKit / 537.36(KHTML,例如Gecko)Chrome / 70.0.3538.110 Safari / 537.36”“ -“

这是/var/log/nginx/error.log中的条目

  

[错误] 1280#1280:* 12连接到上游时,connect()失败(111:连接被拒绝),客户端:172.xx.xxx.xxx,服务器:api-mydomain.trigfig.com,请求:“选项/ dup-check HTTP / 1.1“,上游:” http://127.0.0.1:4001/dup-check“,主机:” api-alpha.mydomain.com“

谢谢,不确定我的配置中缺少什么

1 个答案:

答案 0 :(得分:0)

尝试更改为

server {
        listen        80;
        server_name   alpha.mydomain.com ;

        access_log   /var/log/nginx.access_log  main;

        root /home/mydomain/react-front/dist;

        location / {
            try_files $uri $uri/ /index.html;
        }

    }
   server {
        listen        80;
        server_name   api-alpha.mydomain.com ;

        access_log   /var/log/nginx-api-alpha-access.log  main;

        location /{

            if ($request_method = 'OPTIONS') {
                add_header 'Access-Control-Allow-Origin' '*';
                add_header 'Access-Control-Allow-Methods' 'GET, POST, OPTIONS, PUT, DELETE';
                add_header 'Access-Control-Allow-Headers' 'DNT,User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type,Range,Authorization';
                add_header 'Access-Control-Max-Age' 1728000;
                add_header 'Content-Type' 'text/plain; charset=utf-8';
                add_header 'Content-Length' 0;
                return 204;
             }

             add_header 'Access-Control-Allow-Origin' '*';
             add_header 'Access-Control-Allow-Methods' 'GET, POST, OPTIONS, PUT, DELETE';
             add_header 'Access-Control-Allow-Headers' 'DNT,User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type,Range,Authorization';
             add_header 'Access-Control-Expose-Headers' 'Content-Length,Content-Range,Authorization';

                proxy_pass         http://127.0.0.1:4001/;
                proxy_set_header X-Real-IP $remote_addr;
                proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
                proxy_set_header X-NginX-Proxy true;
                proxy_ssl_session_reuse off;
                proxy_set_header Host $http_host;
                proxy_redirect off;
        }

    }