dtr / ip
An IPv4/v6 Helper Suite for PHP
Installs: 20 349
Dependents: 0
Suggesters: 0
Security: 0
Stars: 22
Watchers: 2
Forks: 11
Open Issues: 3
Requires
- php: >=5.1
Requires (Dev)
- phpunit/phpunit: ^5.6
This package is not auto-updated.
Last update: 2024-11-14 01:15:02 UTC
README
An IPv4/v6 Helper Suite for PHP
Usage:
This class takes both IPv6 (expanded and condensed) and IPv4 addresses into consideration.
You can create the class by passing an IP and CIDR mask one of two ways:
$net = new dTRIP("fe80:dead:15:a:bad:1dea:11:2234/93");
// or
$net = new dTRIP("fe80:dead:15:a:bad:1dea:11:2234", 93);
You can then access different aspects of a network:
$net->getIP(); // returns IP
$net->getCIDR(); // returns CIDR
$net->getNetwork() // return Network ID
$net->getBroadcast() // return Broadcast ID
There is a __toString()
method which will return a JSON-encoded string on the class object:
echo new dTRIP("fe80:dead:15:a:bad:1dea::/65");
The above would return:
{
"ip":"fe80:dead:15:a:bad:1dea::",
"cidr":"65",
"netmask":"ffff:ffff:ffff:ffff:8000::",
"network":"fe80:dead:15:a::",
"broadcast":"fe80:dead:15:a:7fff:ffff:ffff:ffff"
}
Examples:
Here are some examples:
ipv4
$net = new dTRIP("10.22.99.199", 28);
echo $net->getNetwork(); // 10.22.99.192
ipv6
$net = new dTRIP("fe80:dead:15:a:bad:1dea:11:2234", 93);
$net->getNetwork(); // fe80:dead:15:a:bad:1de8::
$net->getBroadcast(); // fe80:dead:15:a:bad:1def:ffff:ffff
Notes:
Although IPv6 does not use the concept of networks and broadcasts, the ranges are still needed to do inclusive searches. Also, IPv6 has a subnet segment, but can still be supernetted/subnetted, which this takes into consideration.