ICode9

精准搜索请尝试: 精确搜索
首页 > 系统相关> 文章详细

带有http2的Nginx背后的asp.net核心-远程IP始终为127.0.0.1

2019-11-09 03:09:57  阅读:276  来源: 互联网

标签:asp-net-core nginx ip-address http2


我在Ubuntu 16.04的Nginx后面托管了一个asp.net网络核心2.0应用程序.

我的设置如下所示:

server {
        listen 443 ssl http2; 
        listen [::]:443 ssl http2;
        ssl on;
...
    location / {
                    proxy_pass http://localhost:5000;
                    proxy_http_version 1.1;
                    proxy_set_header Upgrade $http_upgrade;
                    proxy_set_header Connection keep-alive;
                    proxy_set_header Host $host;
                    proxy_cache_bypass $http_upgrade;
                    proxy_set_header X-Forwarded-Proto-Version $http2;
                    client_max_body_size 32m;
                    keepalive_timeout 200;
                    send_timeout 20;
                    client_body_timeout 50;
            }
}

而且我在Startup.cs中也有这些设置

app.UseForwardedHeaders(new ForwardedHeadersOptions
            {
                ForwardedHeaders = ForwardedHeaders.XForwardedFor |
                                   ForwardedHeaders.XForwardedProto
            });

但是仍然每次当我尝试获取HttpContext.Connection.RemoteIpAddress时,它都会返回127.0.0.1

我应该怎么做才能解决此问题并获得真实的IP地址?

解决方法:

好吧,自己找答案.

不需要此行(但是似乎没有做任何有害的事情)

proxy_set_header X-Forwarded-Proto-Version $http2; 

但是我们需要对Nginx说,在这行代码中设置X-Forwarded-For标头:

proxy_set_header X-Forwarded-For $remote_addr;

标签:asp-net-core,nginx,ip-address,http2
来源: https://codeday.me/bug/20191109/2011235.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有