这基本上是这个问题的重复:How to check an IP address is within a range of two IPs in PHP?
然而,上述问题的解决方案不支持ipv6。是否有支持ipv6的类似解决方案?
答案 0 :(得分:2)
string inet_ntop ( string $in_addr )
此功能可转换32位IPv4或128位IPv6地址(如果是PHP) 在启用IPv6支持的情况下构建到地址系列中 适当的字符串表示。
您还应该看到,
string inet_pton ( string $address )
<?php
$packed = chr(127) . chr(0) . chr(0) . chr(1);
$expanded = inet_ntop($packed);
/* Outputs: 127.0.0.1 */
echo $expanded;
$packed = str_repeat(chr(0), 15) . chr(1);
$expanded = inet_ntop($packed);
/* Outputs: ::1 */
echo $expanded;
?>
PHP 5.1.0中引入了以下两个函数,inet_pton
和inet_pton
。它们的目的是将人类可读的IP地址转换为其打包的in_addr
表示。由于结果不是纯二进制,我们需要使用unpack
函数来应用按位运算符。
这两个功能都支持IPv6和IPv4。唯一的区别是如何从结果中解压缩地址。使用IPv6,您将使用A16解压缩内容,使用IPv4,您将使用A4打开包装。
将前一个放在透视图中是一个小样本输出,以帮助澄清:
// Our Example IP's
$ip4= "10.22.99.129";
$ip6= "fe80:1:2:3:a:bad:1dea:dad";
// ip2long examples
var_dump( ip2long($ip4) ); // int(169239425)
var_dump( ip2long($ip6) ); // bool(false)
// inet_pton examples
var_dump( inet_pton( $ip4 ) ); // string(4)
var_dump( inet_pton( $ip6 ) ); // string(16)
我们在上面证明了inet_ *系列支持IPv6和v4。我们的下一步是将打包结果转换为解压缩变量。
// Unpacking and Packing
$_u4 = current( unpack( "A4", inet_pton( $ip4 ) ) );
var_dump( inet_ntop( pack( "A4", $_u4 ) ) ); // string(12) "10.22.99.129"
$_u6 = current( unpack( "A16", inet_pton( $ip6 ) ) );
var_dump( inet_ntop( pack( "A16", $_u6 ) ) ); //string(25) "fe80:1:2:3:a:bad:1dea:dad"
注意:current函数返回数组的第一个索引。说$ array [0]是等同的。
打开包装后,我们可以看到我们获得了与输入相同的结果。这是一个简单的概念证明,可确保我们不会丢失任何数据。
最后使用,
if ($ip <= $high_ip && $low_ip <= $ip) {
echo "in range";
}
参考:php.net