-1

再会,

我在 PHP 中使用以下代码来获取 IP 地址:

    $IPkey = array('HTTP_CLIENT_IP', 'HTTP_X_FORWARDED_FOR', 'REMOTE_ADDR');

    foreach($IPkey as $name){
        if(isset($_SERVER[$name])) return $_SERVER[$name];
    }

现在有了一个客户,我得到了非常尴尬的结果。

我突然得到以下结果:

  • 2001:1c04:3403:9bf0:a8a6:2d21:8006:159, 172.69.55.30
  • 2001:1c04:3403:9bf0:a8a6:2d21:8006:159, 162.158.111.183
  • 2001:1c04:3403:9bf0:a8a6:2d21:8006:159, 141.101.105.236
  • 2001:1c04:3403:9bf0:a8a6:2d21:8006:159, 172.69.55.208
  • 2001:1c04:3403:9bf0:a8a6:2d21:8006:159, 172.69.55.209

客户声称他仅在一台 PC 上使用该系统。我当然敢怀疑这个说法。

但我根本无法理解这些 IP 地址。这就像附加到 IPv6 地址的 IPv4 地址。

我希望有人能告诉我他们的真实IP是什么,这是他们的内部地址粘贴到他们的路由器地址吗?以及如何避免这种情况?

编辑: 我将尝试再次解释。我使用上面提到的代码来获取 IP 地址。

现在我得到的结果如下所示。看起来我的意思是:

2001:1c04:3403:9bf0:a8a6:2d21:8006:159172.69.55.30

但我得到了一个完整的字符串:2001:1c04:3403:9bf0:a8a6:2d21:8006:159, 172.69.55.30就像这是 IP 地址。在我看来不太可能。但这仍然是返回给我的。

我想知道为什么会这样?

4

1 回答 1

2

你的“钥匙”的顺序很重要。因此,即使您确实需要远程地址,您通常也更有可能以HTTP_X_FORWARDED_FOR. 我想这就是你正在看的那个。它的值是与 HTTP 请求一起发送的 HTTP 标头的值。

HTTP_X_FORWARDED_FOR可以包含多个 IP 地址。当一个请求通过多个代理服务器链接时,每个代理都应将前一个代理的 IP 添加到现有的 X-Forwarded-For 标头中,以便保留整个链。语法是:

X-Forwarded-For: <client>, <proxy1>, <proxy2>

请参阅:https ://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/X-Forwarded-For

由于 IPv4 和 IPv6 地址都不包含逗号,因此您可以查找逗号以查看您是否有多个 IP 地址。如果这样做,您可以使用第一个,即客户端计算机的 IP 地址,或者最后一个,即连接所经过的最后一个代理。

于 2020-10-05T09:18:00.717 回答