Сетевые Функции

Содержание

  • checkdnsrr — Проверяет записи DNS, соответствующие переданному имени узла интернета или IP-адресу
  • closelog — Завершает соединение с системным журналом
  • define_syslog_variables — Инициализирует все syslog переменные
  • dns_check_record — Псевдоним checkdnsrr
  • dns_get_mx — Псевдоним getmxrr
  • dns_get_record — Получение DNS свойств и характеристик хоста
  • fsockopen — Открывает соединение с интернет сокетом или доменным сокетом Unix
  • gethostbyaddr — Получает доменное имя узла, соответствующее переданному IP-адресу
  • gethostbyname — Получает адрес IPv4, соответствующий переданному имени узла интернета
  • gethostbynamel — Возвращает список адресов IPv4, соответствующих переданному доменному имени узла
  • gethostname — Получает имя хоста
  • getmxrr — Получает запись MX, соответствующую переданному доменному имени узла
  • getprotobyname — Получает номер протокола по имени
  • getprotobynumber — Получает имя протокола по номеру
  • getservbyname — Получает номер порта, присвоенного Интернет службе и протоколу
  • getservbyport — Получает Интернет службу, соответствующую заданному порту и протоколу
  • header_register_callback — Вызывает функцию заголовка (header)
  • header_remove — Удаляет предварительно установленные заголовки
  • header — Отправка HTTP заголовка
  • headers_list — Возвращает список переданных (или готовых к передаче) заголовков
  • headers_sent — Проверяет были ли и куда отправлены заголовки
  • http_response_code — Получает или устанавливает код ответа HTTP
  • inet_ntop — Конвертирует упакованный интернет адрес в читаемый формат
  • inet_pton — Конвертирует читаемый IP адрес в упакованное in_addr представление
  • ip2long — Конвертирует строку, содержащую (IPv4) Интернет адрес с точками в допустимый адрес
  • long2ip — Конвертирует (IPv4) адрес Интернет сети в стандартную строку с точками
  • openlog — Открывает соединение к системному журналу
  • pfsockopen — Открывает постоянное соединение с Интернет или сокетом Unix домена
  • setcookie — Посылает cookie
  • setrawcookie — Посылает cookie не преобразовывая значение
  • socket_get_status — Псевдоним stream_get_meta_data
  • socket_set_blocking — Псевдоним stream_set_blocking
  • socket_set_timeout — Псевдоним stream_set_timeout
  • syslog — Генерирует сообщение для системного журнала

Коментарии

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));
}
2001-12-14 21:46:14
http://php5.kiev.ua/manual/ru/ref.network.html
Автор:
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";
}
2003-04-02 23:11:27
http://php5.kiev.ua/manual/ru/ref.network.html
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_paddecbin($lnet),32,"0","STR_PAD_LEFT" );
   
$firstpart=substr($binnet,0,$mask);
   
$binip=str_paddecbin($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...
2003-11-25 11:01:57
http://php5.kiev.ua/manual/ru/ref.network.html
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
2005-02-24 19:16:04
http://php5.kiev.ua/manual/ru/ref.network.html
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!
2006-04-08 17:28:38
http://php5.kiev.ua/manual/ru/ref.network.html
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 = ~((<< (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"); ?>
2007-04-22 05:52:25
http://php5.kiev.ua/manual/ru/ref.network.html
Автор:
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;
}
2007-06-21 11:12:19
http://php5.kiev.ua/manual/ru/ref.network.html
Автор:
This little function might come in handy

<?php
function cidr_range$cidr$chkip=null )
{
   
// Assign IP / mask
   
list($ip,$mask) = explode("/",$cidr);

   
// Sanitize IP
   
$ip1 preg_replace'_(\d+\.\d+\.\d+\.\d+).*$_''$1'"$ip.0.0.0" );

   
// Calculate range
   
$ip2 long2ipip2long$ip1 ) - + ( << ( 32 $mask) ) );

   
// are we cidr range cheking?
   
if ( $chkip != null && ! filter_var$chkipFILTER_VALIDATE_IPFILTER_FLAG_IPV4) === false )
    {
        return 
ip2long$ip1 ) <= ip2long$chkip ) && ip2long$ip2 ) >= ip2long$chkip ) ? true false;
    } else {
        return 
"$ip1 - $ip2";
    }
}

var_dumpcidr_range"127.0/16""127.0.0.1" ) );   // bool(true)
var_dumpcidr_range"127.0/16""192.168.0.1" ) ); // bool(false)
var_dumpcidr_range"192.168.0.0/24" ) );          // string(27) "192.168.0.0 - 192.168.0.255"

?>
2015-11-13 13:40:47
http://php5.kiev.ua/manual/ru/ref.network.html
Автор:
improved version of philippe-at-cyberabuse.org's answer:

<?php
function cidrconv($net) { 
   
$start strtok($net,"/"); 
   
$n 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 = (<< (32 substr(strstr($net"/"), 1))) - 1
   
$bits2 str_pad(decbin($net), 32"0"STR_PAD_LEFT); 
   
$final "";
    for (
$i 0$i 32$i++)
    { 
        if (
$bits1[$i] == $bits2[$i]) $final .= $bits1[$i]; 
        if (
$bits1[$i] == and $bits2[$i] == 0$final .= $bits1[$i]; 
        if (
$bits1[$i] == and $bits2[$i] == 1$final .= $bits2[$i]; 
    } 
    return array(
$startlong2ip(bindec($final))); 
}
?>
2016-06-16 20:15:53
http://php5.kiev.ua/manual/ru/ref.network.html
An improved version of claudiu at cnixs dot com not using split and working with the following: 
ip: 192.168.101.123, CIRD: 192.168.101.144/24 

<?php 
function ipCIDRCheck ($IP$CIDR) {
    list (
$net$mask) = explode ('/'$CIDR);
   
   
$ip_net ip2long ($net);
   
$ip_mask = ~((<< (32 $mask)) - 1);

   
$ip_ip ip2long ($IP);

    return ((
$ip_ip $ip_mask) == ($ip_net $ip_mask));
  }
?>
2017-05-16 17:41:09
http://php5.kiev.ua/manual/ru/ref.network.html

    Поддержать сайт на родительском проекте КГБ