PHP 7.1.0 Release Candidate 4 Released


(PHP 5 >= 5.1.0, PHP 7)

inet_ntopConcertir una dirección de internet empaquetada en una representación legible por humanos


string inet_ntop ( string $in_addr )

Esta función convierte una dirección IPv4 de 32 bit, o una dirección IPv6 de 128 bit (si PHP se construyó con soporte habilitado para IPv6) a una representación de string apropiada para ser legible por humanos.



Una dirección IPv4 de 32 bit, o una dirección IPv6 de 128 bit.

Valores devueltos

Devuelve una representación de string de la dirección o FALSE en caso de error.


Ejemplo #1 Ejemplo de inet_ntop()

chr(127) . chr(0) . chr(0) . chr(1);
$expandida inet_ntop($empaquetada);

/* Salida: */
echo $expandida;

$empaquetada str_repeat(chr(0), 15) . chr(1);
$expandida inet_ntop($empaquetada);

/* Salida: ::1 */
echo $expandida;

Historial de cambios

Versión Descripción
5.3.0 Esta función ahora está disponible en plataformas Windows.

Ver también

  • long2ip() - Convierte una dirección de red (IPv4) en una cadena de texto en formato con puntos estándar de internet
  • ip2long() - Convierte una cadena que contiene una dirección con puntos del Protocolo de Internet (IPv4) en una dirección apropiada
  • inet_pton() - Convertir una dirección IP legible por humanos a su representación in_addr empaquetada

add a note add a note

User Contributed Notes 4 notes

ryansun81 at gmail dot com
6 years ago
For people who wondering what the meaning of this function name:
pton: a presentation(printable) format address to network address
ntop: a network address to presentation(printable) format address
marcus at synchromedia dot co dot uk
1 year ago
PHP's inet_ntop function is not compatible with the binary representation used by MySQL's INET6_ATON function, assuming you are using the recommended method of storing both IPv4 and IPv6 addresses in a VARBINARY(16) field. You need to convert it like this:

* Convert a MySQL binary v4 (4-byte) or v6 (16-byte) IP address to a printable string.
* @param string $ip A binary string containing an IP address, as returned from MySQL's INET6_ATON function
* @return string Empty if not valid.
function inet6_ntop($ip) {
    $l = strlen($ip);
    if ($l == 4 or $l == 16) {
        return inet_ntop(pack('A' . $l, $ip));
    return '';

You don't need a function going the other way because MySQL's INET6_NTOA is already compatible with PHP's inet_pton function.
MagicalTux at FF dot st
11 years ago
For people who need this function but don't have it, I could write a function which should give almost the same result.

function my_inet_ntop($ip) {
    if (
strlen($ip)==4) {
// ipv4
    } elseif(
strlen($ip)==16) {
// ipv6
$ip as $seg) {
$seg{0}=='0') $seg=substr($seg,1);
            if (
$seg!='') {
            } else {
                if (
strpos($res,'::')===false) {
                    if (
substr($res,-1)==':') continue;

I followed IPv6 reprenstation rules :
- A series of "0"s in a 16bit block can by represented by "0".
- A series of blocks containing only "0"s can be suppressed and represented by "::" (this can be done only once)

(source : )

= str_repeat(chr(0), 15) . chr(1);
$expanded = my_inet_ntop($packed);

/* Outputs: ::1 */
echo $expanded;

I checked in CVS (2005-04-25) and didn't find the inet_ntop function (I really needed to handle IPv6) so I implemented it myself !
PandoraBox2007 at gmail dot com
4 years ago
Before inet_pton nice work


no need compare compress data
string inet_ntop ( string $in_addr [, bool $compress = false] )

To Top