Я уже "сделал" это для 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 <aidan@php.net>, Arpad Ray <arpad@php.net>
* @link http://php.net/inet_pton
* @author Arpad Ray <arpad@php.net>
*/
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-адрес в другом формате, чем я делаю (или хочу).