【问题标题】:Client IP Address Inconsistent between ASP.NET 5 Application and IIS LogsASP.NET 5 应用程序和 IIS 日志之间的客户端 IP 地址不一致
【发布时间】:2015-03-26 16:48:12
【问题描述】:

我们正在编写一个 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 地址?

相关软件版本:

  • ASP.NET 5 (vNext)
  • KRE 1.0.0-beta2
  • IIS 8

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

【问题讨论】:

    标签: iis asp.net-core


    【解决方案1】:

    这是由于 Microsoft.AspNet.Loader.IIS 包中的错误造成的。幸运的是,微软的人很快发布了一个修复程序。

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

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2022-01-22
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多