使用 Nginx 和 CloudFlare 时如何将真实 IP 传递给 Gunicorn?

Der*_*wok 5 django nginx gunicorn cloudflare

我有以下 nginx 配置:

http {

    ... <content removed for bevity> ...

    # Cloudflare
    set_real_ip_from   199.27.128.0/21;
    set_real_ip_from   173.245.48.0/20;
    set_real_ip_from   103.21.244.0/22;
    set_real_ip_from   103.22.200.0/22;
    set_real_ip_from   103.31.4.0/22;
    set_real_ip_from   141.101.64.0/18;
    set_real_ip_from   108.162.192.0/18;
    set_real_ip_from   190.93.240.0/20;
    set_real_ip_from   188.114.96.0/20;
    set_real_ip_from   197.234.240.0/22;
    set_real_ip_from   198.41.128.0/17;
    set_real_ip_from   162.158.0.0/15;
    set_real_ip_from   104.16.0.0/12;
    set_real_ip_from   2400:cb00::/32;
    set_real_ip_from   2606:4700::/32;
    set_real_ip_from   2803:f800::/32;
    set_real_ip_from   2405:b500::/32;
    set_real_ip_from   2405:8100::/32;
    real_ip_header     CF-Connecting-IP;

    upstream myproject {
        server unix:/var/www/myproject/gunicorn.sock fail_timeout=0;
    }

    server {

        listen XXX;
        server_name XXXXXX;

        ... <content removed for bevity> ...

        location / {
            proxy_set_header HOST $http_host;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
            proxy_redirect off;
            proxy_pass http://myproject;
        }

    }
Run Code Online (Sandbox Code Playgroud)

然而在 Django 中,以下代码没有向我返回任何内容:

request.META.get('REMOTE_ADDR', '') # this gives me b''
Run Code Online (Sandbox Code Playgroud)

如何填充REMOTE_ADDR用户的真实 IP 地址?

注意:当我删除 nginx 配置的 #Cloudflare 部分时,REMOTE_ADDR会填充 Cloudflare 的 IP 地址。


更新:我已将以下内容添加到我的 nginx 配置中,但request.META.get('REMOTE_ADDR')仍然是空的。

location / {
    ...
    proxy_set_header REMOTE_ADDR $proxy_add_x_forwarded_for;
}
Run Code Online (Sandbox Code Playgroud)

Jac*_*ack 1

CloudFlare 附加X-Forwarded-ForX-Forwarded-Proto标头。您可以获取并使用 X-Forwarded-For 来记录客户的 IP 或传递给另一个代理或您想要的任何内容。

来源:https ://support.cloudflare.com/hc/en-us/articles/200170946-Does-CloudFlare-include-an-X-Forwarded-For-header-