downloads | documentation | faq | getting help | mailing lists | licenses | wiki | reporting bugs | php.net sites | links | conferences | my php.net

search for in the

checkdnsrr> <ncurses_wvline
[edit] Last updated: Mon, 01 Nov 2010

view this page in

XCIII. Funciones de Red

Requisitos

No se necesitan bibliotecas externas para construir esta extensión

Instalación

No se necesita ninguna instalación para usar estas funciones, son parte del núcleo de PHP.

Configuración en tiempo de ejecución

El comportamiento de estas funciones está afectado por los valores definidos en php.ini.

Tabla 1. Opciones de Configuración de Red

NombrePredeterminadoModificableCambios
define_syslog_variables"0"PHP_INI_ALL 
For further details and definitions of the PHP_INI_* constants, see the Apéndice G.

A continuación se presenta una corta explicación de las directivas de configuración.

define_syslog_variables boolean

Indica si deben definirse las diferentes variables syslog (p.ej. $LOG_PID, $LOG_CRON, etc.). Deshabilitar este parámetro es una buena idea desde el punto de vista del rendimiento. En tiempo de ejecución, puede definir estas variables con un llamado a define_syslog_variables().

Tipos de recursos

Esta extensión no tiene ningún tipo de recurso definido.

Constantes predefinidas

Las constantes listadas aqui están siempre disponibles a través del "núcleo PHP".

Tabla 2. Opciones de openlog()

ConstanteDescripción
LOG_CONS si hay un error durante el envío de datos al registro del sistema, escribir directamente a la consola de sistema
LOG_NDELAY abrir la conexión con el registro inmediatamente
LOG_ODELAY (predeterminado) retrasar la apertura de conexión hasta que el primer mensaje sea registrado
LOG_NOWAIT 
LOG_PERRORimprimir mensajes de registro también en stderr
LOG_PIDincluir PID con cada mensaje

Tabla 3. Facilidades de openlog()

ConstanteDescripción
LOG_AUTH mensajes de seguridad/autorización (usar LOG_AUTHPRIV en su lugar en sistemas en donde tal constante está definida)
LOG_AUTHPRIVmensajes de seguridad/autorización (privados)
LOG_CRONdaemonio de reloj (cron y at)
LOG_DAEMONotros daemonios de sistema
LOG_KERNmensajes de kernel
LOG_LOCAL0 ... LOG_LOCAL7reservadas para uso local, no están disponibles en Windows
LOG_LPRsubsistema de impresión de línea
LOG_MAILsubsistema de correo
LOG_NEWSsubsistema de noticias USENET
LOG_SYSLOGmensajes generados internamente por syslogd
LOG_USERmensajes genéricos de nivel de usuario
LOG_UUCPsubsistema UUCP

Tabla 4. Prioridades de syslog() (en orden descendiente)

ConstanteDescripción
LOG_EMERGel sistema es inutilizable
LOG_ALERTdebe tomarse una acción inmediatamente
LOG_CRITcondiciones críticas
LOG_ERRcondiciones de error
LOG_WARNINGcondiciones de advertencia
LOG_NOTICEcondición normal, pero significativa
LOG_INFOmensaje informativo
LOG_DEBUGmensaje de nivel de depuración

Tabla 5. Opciones de dns_get_record()

ConstanteDescripción
DNS_ARecurso de Dirección IPv4
DNS_MXRecurso de Intercambio de Correo
DNS_CNAMERecurso Alias (Nombre Canónico)
DNS_NSRecurso de Autoridad de Servidor de Nombres
DNS_PTRRecurso de Apuntador
DNS_HINFORecurso de Información de Host (Vea los Nombres de Sistemas Operativos de IANA para consultar el significado de estos valores)
DNS_SOAComienzo de Recurso de Autoridad
DNS_TXTRecurso de Texto
DNS_ANYCualquier Registro de Recurso. En la mayoría de sistemas, éste valor devuelve todos los registros de recurso, sin embargo, no debería confiarse en él para usos críticos. Pruebe con DNS_ALL en su lugar.
DNS_AAAARecurso de Dirección IPv6
DNS_ALLConsultar el nombre de servidor iterativamente para cada tipo de registro disponible.
Tabla de contenidos
checkdnsrr --  Chequea registros DNS correspondientes a un nombre de host o dirección IP de Internet dado
closelog -- Cierra la conexión con el registro del sistema
debugger_off -- Deshabilita el depurador interno de PHP (PHP 3)
debugger_on -- Habilitar el depurador interno de PHP (PHP 3)
define_syslog_variables -- Inicializa todas las constantes relacionadas con syslog
dns_check_record -- Sinónimo para checkdnsrr()
dns_get_mx -- Sinónimo para getmxrr()
dns_get_record --  Recuperar Registros de Recursos DNS asociados con un nombre de servidor huésped
fsockopen --  Abrir una conexión de sockets de dominio de Internet o Unix
gethostbyaddr --  Obtener el nombre del host de Internet correspondiente a una dirección IP dada
gethostbyname --  Obtener la dirección IP correspondiente a un nombre de host de Internet dado
gethostbynamel --  Obtener una lista de direcciones IP correspondientes a un nombre de host de Internet dado
getmxrr --  Obtener los registros MX correspondientes a un nombre de host de Internet dado
getprotobyname --  Obtener el número de protocolo asociado con el nombre de protocolo
getprotobynumber --  Obtener el nombre de protocolo asociado con un número de protocolo
getservbyname --  Obtener el número de puerto asociado con un servicio y protocolo de Internet
getservbyport --  Obtener el servicio de Internet que corresponde con el puerto y protocolo
inet_ntop --  Converts a packed internet address to a human readable representation
inet_pton --  Converts a human readable IP address to its packed in_addr representation
ip2long --  Convierte una cadena que contiene una dirección con puntos del Protocolo de Internet (IPv4) en una dirección apropiada
long2ip --  Convierte una dirección de red Internet (IPv4) a una cadena en formato estándar de Internet con puntos
openlog -- Abrir una conexión con el registro del sistema
pfsockopen --  Abrir una conexión persistente de sockets de Internet o dominio Unix
socket_get_status -- Alias of stream_get_meta_data()
socket_set_blocking -- Alias of stream_set_blocking()
socket_set_timeout -- Alias of stream_set_timeout()
syslog -- Generar un mensaje de registro de sistema


checkdnsrr> <ncurses_wvline
[edit] Last updated: Mon, 01 Nov 2010
 
add a note add a note User Contributed Notes Funciones de Red
eicto@NOSPAM 15-Mar-2012 10:37
That function return ip ranges
<?php

function iprange($ip,$mask=24,$return_array=FALSE) {
   
$corr=(pow(2,32)-1)-(pow(2,32-$mask)-1);
   
$first=ip2long($ip) & ($corr);
   
$length=pow(2,32-$mask)-1;
    if (!
$return_array) {
    return array(
       
'first'=>$first,
       
'size'=>$length+1,
       
'last'=>$first+$length,
       
'first_ip'=>long2ip($first),
       
'last_ip'=>long2ip($first+$length)
        );
    }
   
$ips=array();
    for (
$i=0;$i<=$length;$i++) {
       
$ips[]=long2ip($first+$i);
    }
    return
$ips;
}

$test1=iprange('192.168.5.12',18);
$test2=iprange('192.168.1.12',28,TRUE);
echo
print_r($test1,1)."\n".print_r($test2,1)."\n";
----------------
<?
Array
(
    [
first] => 3232235520
   
[size] => 16384
   
[last] => 3232251903
   
[first_ip] => 192.168.0.0
   
[last_ip] => 192.168.63.255
)

Array
(
    [
0] => 192.168.1.0
   
[1] => 192.168.1.1
   
[2] => 192.168.1.2
   
[3] => 192.168.1.3
   
[4] => 192.168.1.4
   
[5] => 192.168.1.5
   
[6] => 192.168.1.6
   
[7] => 192.168.1.7
   
[8] => 192.168.1.8
   
[9] => 192.168.1.9
   
[10] => 192.168.1.10
   
[11] => 192.168.1.11
   
[12] => 192.168.1.12
   
[13] => 192.168.1.13
   
[14] => 192.168.1.14
   
[15] => 192.168.1.15
)

?>
David GASTALDIN 21-Jun-2007 08:12
Here a IP-Range to CIDRs function that I wrote for the purpose of filling my Postfix client.cidr with ripe-ncc data to block spamming from useless countries. Strcmp functions are meant to work around the silly PHP string comparison which inevitably tries compare strings as numbers when possible. I'll make no comment about that fact ... bit I have to bite my tong hard :

function PlageVersCIDRs($ip_min, $ip_max) {
    $cidrs = array();
    $ip_min_bin = sprintf('%032b', $ip_min);
    $ip_max_bin = sprintf('%032b', $ip_max);
    $ip_cour_bin = $ip_min_bin;
    while (strcmp($ip_cour_bin, $ip_max_bin) <= 0) {
        $lng_reseau = 32;
        $ip_reseau_bin = $ip_cour_bin;
        while (($ip_cour_bin[$lng_reseau - 1] == '0') && (strcmp(substr_replace($ip_reseau_bin, '1', $lng_reseau - 1, 1), $ip_max_bin) <= 0)) {
            $ip_reseau_bin[$lng_reseau - 1] = '1';
            $lng_reseau--;
        }
        $cidrs[] = long2ip(bindec($ip_cour_bin)).'/'.$lng_reseau;
        $ip_cour_bin = sprintf('%032b', bindec($ip_reseau_bin) + 1);
    }
    return $cidrs;
}
claudiu at cnixs dot com 22-Apr-2007 02:52
A simple and very fast function to check against CIDR.

Your previous examples are too complicated and involves a lot of functions call.

Here it is (only with arithmetic operators and call only to ip2long () and split() ):
<?php
 
function ipCIDRCheck ($IP, $CIDR) {
    list (
$net, $mask) = split ("/", $CIDR);
   
   
$ip_net = ip2long ($net);
   
$ip_mask = ~((1 << (32 - $mask)) - 1);

   
$ip_ip = ip2long ($IP);

   
$ip_ip_net = $ip_ip & $ip_mask;

    return (
$ip_ip_net == $ip_net);
  }
?>
call example: <?php echo ipCheck ("192.168.1.23", "192.168.1.0/24"); ?>
dand at ddchosting.com 08-Apr-2006 02:28
When I was working on a project I ran into this problem with redirecting. My solution is as follows:
header("Refresh: 5; url=../main/main.php?".session_id()."");

This allowed me to pass the session_id() which is used throughout site to make sure user has loged in.
I hope this helps!
metator at netcabo dot pt 28-Jul-2005 07:34
Ups. The function has a bug, though the example still works with it. Just replace the $_POST variables by the function parameters.

<?
function isIPIn($ip, $net, $mask) {
  
//doesn't check for the return value of ip2long
  
$ip = ip2long($ip);
  
$rede = ip2long($net);
  
$mask = ip2long($mask);
 
  
//AND
  
$res = $ip & $mask;
 
   return (
$res == $rede);
}
?>
metator at netcabo dot pt 27-Jul-2005 08:22
Regarding samuele's note:

You can get faster code if you apply directly what happens in  network devices, such as routers. If you AND (logic operation) the remote ip against the local netmask the result will be the network ip if the remote ip is from the local network. Example:

    192.168.0.16 = 11000000.10101000.00000000.00010000
& 255.255.255.0 = 11111111.11111111.11111111.00000000
--------------------------------------------------------------
   192.168.0.0 = 11000000.10101000.00000000.00000000

And now the code. My example uses a html form where you place the values you want to test:

<HTML><HEAD><TITLE>Check IP</TITLE>
</HEAD><BODY>
    <form action="<?php echo $_SERVER['PHP_SELF']; ?>" method="POST">

Hope you find this useful.
        IP to check: <input type="text" name="ip"> <br>
        Local network ip: <input type="text" name="net"> <br>
        Local netmask: <input type="text" name="mask"> <br>
        <input type="submit" name="check" value="Check it!">
    </form>
    <?php

/**
 * @param string $ip IP to check in dotted decimal format
 * @param string $net Network IP in dotted decimal format
 * @param string $mask Netmask in dotted decimal format
 * @returns true if the ip belongs to the network, false otherwise
 **/
function isIPIn($ip, $net, $mask) {
   
//doesn't check for the return value of ip2long
   
$ip = ip2long($_POST['ip']);
   
$rede = ip2long($_POST['net']);
   
$mask = ip2long($_POST['mask']);
   
   
//AND
   
$res = $ip & $mask;
   
    return (
$res == $rede);
}

if (isset(
$_POST['check'])) {
     echo
isIPIn($_POST['ip'], $_POST['net'], $_POST['mask']) ? "IP IN.": "IP OUT.";
}
 
?>
</BODY><HTML>
nexxer at rogers dot com 24-Feb-2005 05:16
In Trevor Hemsley's translation of the perl range2cidr function, the

while ($end > $start)

condition should be

while ($end >= $start)

otherwise it won't work for /32s, ie if you feed range2cidr("1.2.3.4", "1.2.3.4").

-- nex
samuele at norsam dot org 25-Nov-2003 09:01
To find if an IP is in a net/mask (very fast):
<?php
function isIPIn($ip,$net,$mask) {
  
$lnet=ip2long($net);
  
$lip=ip2long($ip);
  
$binnet=str_pad( decbin($lnet),32,"0","STR_PAD_LEFT" );
  
$firstpart=substr($binnet,0,$mask);
  
$binip=str_pad( decbin($lip),32,"0","STR_PAD_LEFT" );
  
$firstip=substr($binip,0,$mask);
   return(
strcmp($firstpart,$firstip)==0);
   }
?>

This function can be compacted, avoiding some variable settings, but the function will not be too clear to read...
Example code, used to made a kind of location service network-based:

<?php
$n
= array ( "192.168.0.0/16"   => "TUSCANY",
            
"192.168.1.0/24"   => "- Florence",
            
"192.168.2.0/24"   => "- Pisa",
            
"192.168.3.0/24"   => "- Siena",
            
"192.168.64.0/21" => "- Tuscan Archipelago",
            
"192.168.64.0/23" => "--- Elba Island",
            
"192.168.66.0/24" => "--- Capraia Island",
            
"192.168.67.0/24" => "--- Giannutri Island");

// Normally you should use the following line
$myip = $HTTP_SERVER_VARS['REMOTE_ADDR'];
// This is first example: returns Tuscany/Pisa
$myip = "192.168.2.33";
// This is second example: returns Tuscany/T.Arch./Elba
$myip = "192.168.65.34";

echo
"Your position:<br />\n";
foreach (
$n as $k=>$v ) {
   list(
$net,$mask)=split("/",$k);
   if (
isIPIn($myip,$net,$mask)) {
       echo
$n[$k]."<br />\n"; }
   }
?>

and so on...
anderson at piq dot com dot br 06-Aug-2003 10:10
If you want to get the interface of an IP, based on the local route table, use this.

function GetIfaceforIP($user_ip)
{
    $route = "/bin/netstat -rn";

    exec($route, $aoutput);
    foreach($aoutput as $key => $line)
    {
        if($key > 1)
        {
            $line = ereg_replace("[[:space:]]+",",",$line);
            list($network, $gateway, $mask, $flags, $mss, $window, $irtt, $iface) = explode(",", $line)
            if((ip2long($user_ip) & ip2long($mask)) == ip2long($network))
            {
                return $iface;
            }
        }
    }
}
02-Apr-2003 08:11
Alternative cidr_conv function - a little easier to follow

function cidr_conv($cidr_address) {
  $first = substr($cidr_address, 0, strpos($cidr_address, "/"));
  $netmask = substr(strstr($cidr_address, "/"), 1);

  $first_bin = str_pad(decbin(ip2long($first)), 32, "0", STR_PAD_LEFT);
  $netmask_bin = str_pad(str_repeat("1", (integer)$netmask), 32, "0", STR_PAD_RIGHT);
 
  for ($i = 0; $i < 32; $i++) {
    if ($netmask_bin[$i] == "1")
      $last_bin .= $first_bin[$i];
    else
      $last_bin .= "1";
  }

  $last = long2ip(bindec($last_bin));

  return "$first - $last";
}
trevor-hemsley at nospam dot dial dot pipex dot com 16-Oct-2002 11:53
Previous example of IP range to CIDR list does not cope with ranges as well as the perl Net::Netmask range2cidrlist() function. In PHP this looks like

<?
function imask($this)
{
// use base_convert not dechex because dechex is broken and returns 0x80000000 instead of 0xffffffff
return base_convert((pow(2,32) - pow(2, (32-$this)))), 10, 16);
}

function
imaxblock($ibase, $tbit)
{
while (
$tbit > 0)
{
$im = hexdec(imask($tbit-1));
$imand = $ibase & $im;
if (
$imand != $ibase)
{
break;
}
$tbit--;
}
return
$tbit;
}

function
range2cidrlist($istart, $iend)
{
// this function returns an array of cidr lists that map the range given
$s = explode(".", $istart);
// PHP ip2long does not handle leading zeros on IP addresses! 172.016 comes back as 172.14, seems to be treated as octal!
$start = "";
$dot = "";
while (list(
$key,$val) = each($s))
{
$start = sprintf("%s%s%d",$start,$dot,$val);
$dot = ".";
}
$end = "";
$dot = "";
$e = explode(".",$iend);
while (list(
$key,$val) = each($e))
{
$end = sprintf("%s%s%d",$end,$dot,$val);
$dot = ".";
}
$start = ip2long($start);
$end = ip2long($end);
$result = array();
while (
$end > $start)
{
$maxsize = imaxblock($start,32);
$x = log($end - $start + 1)/log(2);
$maxdiff = floor(32 - floor($x));
$ip = long2ip($start);
if (
$maxsize < $maxdiff)
{
$maxsize = $maxdiff;
}
array_push($result,"$ip/$maxsize");
$start += pow(2, (32-$maxsize));
}
return
$result;
}
?>
philippe-at-cyberabuse.org 12-Oct-2002 03:49
... and this one will do the opposite (o return NULL for invalid netblocks) :

1.0.0.0 1.0.255.255 -> 1.0.0.0/16
1.0.0.0 1.3.255.255 -> 1.0.0.0/14
192.168.0.0 192.168.0.255 -> 192.168.0.0/24

function ip2cidr($ip_start,$ip_end) {
if(long2ip(ip2long($ip_start))!=$ip_start or long2ip(ip2long($ip_end))!=$ip_end) return NULL;
$ipl_start=(int)ip2long($ip_start);
$ipl_end=(int)ip2long($ip_end);
if($ipl_start>0 && $ipl_end<0) $delta=($ipl_end+4294967296)-$ipl_start;
else $delta=$ipl_end-$ipl_start;
$netmask=str_pad(decbin($delta),32,"0","STR_PAD_LEFT");
if(ip2long($ip_start)==0 && substr_count($netmask,"1")==32) return "0.0.0.0/0";
if($delta<0 or ($delta>0 && $delta%2==0)) return NULL;
for($mask=0;$mask<32;$mask++) if($netmask[$mask]==1) break;
if(substr_count($netmask,"0")!=$mask) return NULL;
return "$ip_start/$mask";
}
philippe-at-cyberabuse.org 14-Dec-2001 07:46
PHP miss CIDR functions.

This one will convert a CIDR like this:
0.0.0.0/16 -> 0.0.0.0 - 0.0.255.255
127.0/16 -> 127.0.0.0 - 127.0.255.255
etc...

function cidrconv($net) {
$start=strtok($net,"/");
$n=3-substr_count($net, ".");
if ($n>0) { for ($i=$n;$i>0;$i--) $start.=".0"; }
$bits1=str_pad(decbin(ip2long($start)),32,"0","STR_PAD_LEFT");
$net=pow(2,(32-substr(strstr($net,"/"),1)))-1;
$bits2=str_pad(decbin($net),32,"0","STR_PAD_LEFT");
for ($i=0;$i<32;$i++) {
if ($bits1[$i]==$bits2[$i]) $final.=$bits1[$i];
if ($bits1[$i]==1 and $bits2[$i]==0) $final.=$bits1[$i];
if ($bits1[$i]==0 and $bits2[$i]==1) $final.=$bits2[$i];
}
return $start." - ".long2ip(bindec($final));
}

 
show source | credits | sitemap | contact | advertising | mirror sites