$subnet = trim($subnet);
if (strpos($subnet, '/') !== false) { /// type 1
list($ip, $mask) = explode('/', $subnet);
+ if ($mask === '') {
+ $mask = 32;
+ }
$mask = 0xffffffff << (32 - $mask);
$found = ((ip2long($addr) & $mask) == (ip2long($ip) & $mask));
} else if (strpos($subnet, '-') !== false) {/// type 3
$subnetrange[0] <= $lastaddrpart && $lastaddrpart <= $subnetrange[1]);
}
} else { /// type 2
- $found = (strpos($addr, $subnet) === 0);
+ if ($subnet[strlen($subnet) - 1] != '.') {
+ $subnet .= '.';
+ }
+ $found = (strpos($addr . '.', $subnet) === 0);
}
if ($found) {
$this->assertTrue(address_in_subnet('123.121.234.15', '123.121.234.2/28'));
$this->assertFalse(address_in_subnet('123.121.234.16', '123.121.234.2/28'));
$this->assertFalse(address_in_subnet('123.121.234.255', '123.121.234.2/28'));
- $this->assertTrue(address_in_subnet('123.121.234.1', '123.121.'));
+ $this->assertTrue(address_in_subnet('123.121.234.0', '123.121.234.0/')); // / is like /32.
+ $this->assertFalse(address_in_subnet('123.121.234.1', '123.121.234.0/'));
+ $this->assertFalse(address_in_subnet('232.232.232.232', '123.121.234.0/0'));
$this->assertFalse(address_in_subnet('123.122.234.1', '123.121.'));
$this->assertFalse(address_in_subnet('223.121.234.1', '123.121.'));
+ $this->assertTrue(address_in_subnet('123.121.234.1', '123.121'));
+ $this->assertFalse(address_in_subnet('123.122.234.1', '123.121'));
+ $this->assertFalse(address_in_subnet('223.121.234.1', '123.121'));
+ $this->assertFalse(address_in_subnet('123.121.234.100', '123.121.234.10'));
$this->assertFalse(address_in_subnet('123.121.234.9', '123.121.234.10-20'));
$this->assertTrue(address_in_subnet('123.121.234.10', '123.121.234.10-20'));
$this->assertTrue(address_in_subnet('123.121.234.15', '123.121.234.10-20'));