mirror of
https://github.com/phpbb/phpbb.git
synced 2025-08-05 00:07:44 +02:00
[ticket/9802] Only check for IPv4-mapped address when address is IPv6.
PHPBB3-9802
This commit is contained in:
@@ -278,13 +278,12 @@ class session
|
|||||||
|
|
||||||
foreach ($ips as $ip)
|
foreach ($ips as $ip)
|
||||||
{
|
{
|
||||||
// check IPv4 first, the IPv6 is hopefully only going to be used very seldomly
|
if (preg_match(get_preg_expression('ipv4'), $ip))
|
||||||
if (!preg_match(get_preg_expression('ipv4'), $ip) && !preg_match(get_preg_expression('ipv6'), $ip))
|
|
||||||
{
|
{
|
||||||
// Just break
|
$this->ip = $ip;
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
|
else if (preg_match(get_preg_expression('ipv6'), $ip))
|
||||||
|
{
|
||||||
// Quick check for IPv4-mapped address in IPv6
|
// Quick check for IPv4-mapped address in IPv6
|
||||||
if (stripos($ip, '::ffff:') === 0)
|
if (stripos($ip, '::ffff:') === 0)
|
||||||
{
|
{
|
||||||
@@ -296,9 +295,15 @@ class session
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Use the last in chain
|
|
||||||
$this->ip = $ip;
|
$this->ip = $ip;
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// We want to use the last valid address in the chain
|
||||||
|
// Leave foreach loop when address is invalid
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
$this->load = false;
|
$this->load = false;
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user