Я уже "сделал" это для IPv4;
$ip = '127.0.0.1'; // example
$ip = explode('.',$ip);
if( count($ip) != 4 ) $ip = array(0,0,0,0); // wrong ip format, default to 0.0.0.0
return chr($ip[0]) . chr($ip[1]) . chr($ip[2]) . chr($ip[3]);
Мне нужно сделать то же самое и для IPv6. Прочитав спецификацию IPv6 (признаюсь, что я не читал ее все), я заметил несколько странностей ("исключений"), таких как набор 0, который можно сжать до двойного двоеточия: " :0000:0000"=>"::" (если я правильно понял). Я также видел, как вы можете иметь строку в стиле IPv4 внутри строки IPv6: 0:0:0:0:0:0:127.0.0.1
Начнем с того, что я понятия не имею, с чего начать.
Благодаря Альваро теперь у меня есть реализация inet_pton на чистом PHP:
/**
* @copyright 2004-2007 Aidan Lister <[email protected]>, Arpad Ray <[email protected]>
* @link http://php.net/inet_pton
* @author Arpad Ray <[email protected]>
*/
function php_compat_inet_pton($address) {
$r = ip2long($address);
if ($r !== false && $r != -1) return pack('N', $r);
$delim_count = substr_count($address, ':');
if ($delim_count < 1 || $delim_count > 7) return false;
$r = explode(':', $address);
$rcount = count($r);
if (($doub = array_search('', $r, 1)) !== false) {
$length = (!$doub || $doub == $rcount - 1 ? 2 : 1);
array_splice($r, $doub, $length, array_fill(0, 8 + $length - $rcount, 0));
}
$r = array_map('hexdec', $r);
array_unshift($r, 'n*');
$r = call_user_func_array('pack', $r);
return $r;
}
Проблема в том, что я не совсем понимаю, что он делает. Проблема в том, что я не могу просто использовать такую функцию, поскольку (во-первых) я знаю, что она упаковывает IP-адрес в другой формат, чем я делаю (или хочу).