Cache ipCheck
This commit is contained in:
parent
102f930e70
commit
bcb80569cb
|
@ -18,6 +18,8 @@ namespace Symfony\Component\HttpFoundation;
|
||||||
*/
|
*/
|
||||||
class IpUtils
|
class IpUtils
|
||||||
{
|
{
|
||||||
|
private static $checkedIps = array();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This class should not be instantiated.
|
* This class should not be instantiated.
|
||||||
*/
|
*/
|
||||||
|
@ -61,26 +63,31 @@ class IpUtils
|
||||||
*/
|
*/
|
||||||
public static function checkIp4($requestIp, $ip)
|
public static function checkIp4($requestIp, $ip)
|
||||||
{
|
{
|
||||||
|
$cacheKey = $requestIp.'-'.$ip;
|
||||||
|
if (isset(self::$checkedIps[$cacheKey])) {
|
||||||
|
return self::$checkedIps[$cacheKey];
|
||||||
|
}
|
||||||
|
|
||||||
if (!filter_var($requestIp, FILTER_VALIDATE_IP, FILTER_FLAG_IPV4)) {
|
if (!filter_var($requestIp, FILTER_VALIDATE_IP, FILTER_FLAG_IPV4)) {
|
||||||
return false;
|
return self::$checkedIps[$cacheKey] = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (false !== strpos($ip, '/')) {
|
if (false !== strpos($ip, '/')) {
|
||||||
list($address, $netmask) = explode('/', $ip, 2);
|
list($address, $netmask) = explode('/', $ip, 2);
|
||||||
|
|
||||||
if ($netmask === '0') {
|
if ($netmask === '0') {
|
||||||
return filter_var($address, FILTER_VALIDATE_IP, FILTER_FLAG_IPV4);
|
return self::$checkedIps[$cacheKey] = filter_var($address, FILTER_VALIDATE_IP, FILTER_FLAG_IPV4);
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($netmask < 0 || $netmask > 32) {
|
if ($netmask < 0 || $netmask > 32) {
|
||||||
return false;
|
return self::$checkedIps[$cacheKey] = false;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
$address = $ip;
|
$address = $ip;
|
||||||
$netmask = 32;
|
$netmask = 32;
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0 === substr_compare(sprintf('%032b', ip2long($requestIp)), sprintf('%032b', ip2long($address)), 0, $netmask);
|
return self::$checkedIps[$cacheKey] = 0 === substr_compare(sprintf('%032b', ip2long($requestIp)), sprintf('%032b', ip2long($address)), 0, $netmask);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -100,6 +107,11 @@ class IpUtils
|
||||||
*/
|
*/
|
||||||
public static function checkIp6($requestIp, $ip)
|
public static function checkIp6($requestIp, $ip)
|
||||||
{
|
{
|
||||||
|
$cacheKey = $requestIp.'-'.$ip;
|
||||||
|
if (isset(self::$checkedIps[$cacheKey])) {
|
||||||
|
return self::$checkedIps[$cacheKey];
|
||||||
|
}
|
||||||
|
|
||||||
if (!((extension_loaded('sockets') && defined('AF_INET6')) || @inet_pton('::1'))) {
|
if (!((extension_loaded('sockets') && defined('AF_INET6')) || @inet_pton('::1'))) {
|
||||||
throw new \RuntimeException('Unable to check Ipv6. Check that PHP was not compiled with option "disable-ipv6".');
|
throw new \RuntimeException('Unable to check Ipv6. Check that PHP was not compiled with option "disable-ipv6".');
|
||||||
}
|
}
|
||||||
|
@ -108,7 +120,7 @@ class IpUtils
|
||||||
list($address, $netmask) = explode('/', $ip, 2);
|
list($address, $netmask) = explode('/', $ip, 2);
|
||||||
|
|
||||||
if ($netmask < 1 || $netmask > 128) {
|
if ($netmask < 1 || $netmask > 128) {
|
||||||
return false;
|
return self::$checkedIps[$cacheKey] = false;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
$address = $ip;
|
$address = $ip;
|
||||||
|
@ -119,7 +131,7 @@ class IpUtils
|
||||||
$bytesTest = unpack('n*', @inet_pton($requestIp));
|
$bytesTest = unpack('n*', @inet_pton($requestIp));
|
||||||
|
|
||||||
if (!$bytesAddr || !$bytesTest) {
|
if (!$bytesAddr || !$bytesTest) {
|
||||||
return false;
|
return self::$checkedIps[$cacheKey] = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
for ($i = 1, $ceil = ceil($netmask / 16); $i <= $ceil; ++$i) {
|
for ($i = 1, $ceil = ceil($netmask / 16); $i <= $ceil; ++$i) {
|
||||||
|
@ -127,10 +139,10 @@ class IpUtils
|
||||||
$left = ($left <= 16) ? $left : 16;
|
$left = ($left <= 16) ? $left : 16;
|
||||||
$mask = ~(0xffff >> $left) & 0xffff;
|
$mask = ~(0xffff >> $left) & 0xffff;
|
||||||
if (($bytesAddr[$i] & $mask) != ($bytesTest[$i] & $mask)) {
|
if (($bytesAddr[$i] & $mask) != ($bytesTest[$i] & $mask)) {
|
||||||
return false;
|
return self::$checkedIps[$cacheKey] = false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return true;
|
return self::$checkedIps[$cacheKey] = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Reference in New Issue