ASP.NET 5 应用程序和 IIS 日志之间的客户端 IP 地址不一致

Client IP Address Inconsistent between ASP.NET 5 Application and IIS Logs

我们正在编写一个 ASP.NET 5 (vNext) 应用程序,其中部分包括根据用户的 IP 地址对用户位置进行地理编码。我们正在尝试使用从网络上的许多示例中找到的以下代码来获取客户端的 IP 地址:

var connection = context.HttpContext.GetFeature<IHttpConnectionFeature>();
if (connection != null) {
    clientIpAddress = connection.RemoteIpAddress.ToString();
}

当我们记录来自IHttpConnectionFeatureclientIpAddress时,我们发现IP地址不正确。

但是,我们确实注意到 IIS 正在捕获正确的客户端 IP 地址。我们通过 IIS 控制面板检查请求看到了这一点。

因此,在 IIS 请求和我们的应用程序代码之间的某个地方,客户端的 IP 地址正在被修改,或者我们的应用程序代码无法与 IIS 一起正常工作。或者 IIS 是否有可能在解密客户端的 IP 地址时执行额外的工作 - 我们需要在应用程序代码中模拟的工作。

为什么客户端的IP地址在IIS请求日志中是正确的,而在我们上面的应用程序代码中却不正确?我们如何在代码中获取正确的客户端 IP 地址?

相关软件版本:

更新: 我们 运行 同一 IIS 服务器上的 .NET 4.5 应用程序使用 Request.UserHostAddress 检索 IP 地址,它还检索了正确的IP(同一个 IIS 正在记录),所以这似乎是新的 .NET 5 代码的问题。

这是由于 Microsoft.AspNet.Loader.IIS 包中的一个错误。幸运的是,Microsoft 的人员迅速发布了修复程序。

有关更多上下文,请参阅 Github 问题:https://github.com/aspnet/HttpAbstractions/issues/181