php达成获取局域网全部用户的微机IP和主机名、及mac地址完整实例

那是二个能够获得到用户访问新闻的PHP类,包涵:ip地址、地理音讯、操作系统、语言、浏览器和isp等等。获取地理地方和ISP信息是伸手的Baidu隐藏接口。
代码如下:测试地方:
原文:

代码一:

依附现存IP地址获取其地理地点(省份,城市等)的方法

本文所述php实例能够成功获取局域网全部用户的ComputerIP和主机名、及mac地址的效益,对于php程序设计人士有断定的参照借鉴价值。完整代码如下:

[PHP]代码

function getip() {
  static $ip = '';
  $ip = $_SERVER['REMOTE_ADDR'];
  if(isset($_SERVER['HTTP_CDN_SRC_IP'])) {
    $ip = $_SERVER['HTTP_CDN_SRC_IP'];
  } elseif (isset($_SERVER['HTTP_CLIENT_IP']) && preg_match('/^([0-9]{1,3}\.){3}[0-9]{1,3}$/', $_SERVER['HTTP_CLIENT_IP'])) {
    $ip = $_SERVER['HTTP_CLIENT_IP'];
  } elseif(isset($_SERVER['HTTP_X_FORWARDED_FOR']) AND preg_match_all('#\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}#s', $_SERVER['HTTP_X_FORWARDED_FOR'], $matches)) {
    foreach ($matches[0] AS $xip) {
      if (!preg_match('#^(10|172\.16|192\.168)\.#', $xip)) {
        $ip = $xip;
        break;
      }
    }
  }
  return $ip;
}
function GetIpLookup($ip = ''){  
  if(empty($ip)){  
    return '请输入IP地址'; 
  }  
  $res = @file_get_contents('http://int.dpool.sina.com.cn/iplookup/iplookup.php?format=js&ip=' . $ip);  
  if(empty($res)){ return false; }  
  $jsonMatches = array();  
  preg_match('#\{.+?\}#', $res, $jsonMatches);  
  if(!isset($jsonMatches[0])){ return false; }  
  $json = json_decode($jsonMatches[0], true);  
  if(isset($json['ret']) && $json['ret'] == 1){  
    $json['ip'] = $ip;  
    unset($json['ret']);  
  }else{  
    return false;  
  }  
  return $json;  
} 
$ipInfos = GetIpLookup('123.125.114.144'); //baidu.com IP地址  
var_dump($ipInfos); 
<?php
$bIp = gethostbyname($_ENV['COMPUTERNAME']); //获取本机的局域网IP
echo "本机IP:",$bIp,"\n";
echo "本机主机名:",gethostbyaddr($bIp),"\n\n\n"; //gethostbyaddr 函数可以根据局域网IP获取主机名
//默认网关IP
list($ipd1,$ipd2,$ipd3) = explode('.',$bIp);
$mask = $ipd1 . "." . $ipd2 . "." . $ipd3 ;
exec('arp -a',$aIp); //获取局域网中的其他IP
foreach( $aIp as $ipv) {
 if(strpos($ipv,'接口') !== false) {//一下显示的IP是否是当前局域网中的 而不是其他的类型 可以在cmd下试一下命令
 $bool = false;
 preg_match('/(?:(?:25[0-5]|2[0-4]\d|((1\d{2})|([1-9]?\d)))\.){3}(?:25[0-5]|2[0-4]\d|((1\d{2})|([1-9]?\d)))/',$ipv,$arr);
 if(strcmp($arr[0],$bIp) == 0) {
  $bool = true;
 }
 } else {
 if($bool) {
  $str = preg_replace('/\s+/', '|', $ipv);
  $sArr = explode('|',$str);
  if($sArr[1] == 'Internet' || empty($sArr[1])) {
  continue;
  }
  //去除默认网关
  if(strcmp($mask . ".1", $sArr[1]) == 0) {
  continue;
  }
  //去除同网关下255的IP
  if(strcmp($mask . ".255", $sArr[1]) == 0) {
  continue;
  }
  //去除组播IP
  list($cIp) = explode('.', $sArr[1]);
  if($cIp >= 224 && $cIp <= 239) {
  continue;
  }
  echo "IP地址:|",$sArr[1],"|\n";
  echo "MAC地址:",$sArr[2],"\n";
  echo "主机名:",gethostbyaddr($sArr[1]),"\n";
  echo "\n\n";
 }
 }
}
<?php   
/**  
 * 获取访客信息的类:语言、浏览器、操作系统、IP、地理位置、ISP。  
 * 日期:2011-09-13  
 * 作者:www.itwhy.org  
 * 使用:  
 *      $obj = new class_guest_info;  
 *      $obj->GetLang();        //获取访客语言:简体中文、繁體中文、English。  
 *      $obj->GetBrowser();     //获取访客浏览器:MSIE、Firefox、Chrome、Safari、Opera、Other。  
 *      $obj->GetOS();          //获取访客操作系统:Windows、MAC、Linux、Unix、BSD、Other。  
 *      $obj->GetIP();          //获取访客IP地址。  
 *      $obj->GetAdd();         //获取访客地理位置,使用 Baidu 隐藏接口。  
 *      $obj->GetIsp();         //获取访客ISP,使用 Baidu 隐藏接口。  
 */  
class class_guest_info{   
    function GetLang() {   
        $Lang = substr($_SERVER['HTTP_ACCEPT_LANGUAGE'], 0, 4);   
        //使用substr()截取字符串,从 0 位开始,截取4个字符   
        if (preg_match('/zh-c/i',$Lang)) {   
        //preg_match()正则表达式匹配函数   
            $Lang = '简体中文';   
        }   
        elseif (preg_match('/zh/i',$Lang)) {   
            $Lang = '繁體中文';   
        }   
        else {   
            $Lang = 'English';   
        }   
        return $Lang;   
    }   
    function GetBrowser() {   
        $Browser = $_SERVER['HTTP_USER_AGENT'];   
        if (preg_match('/MSIE/i',$Browser)) {   
            $Browser = 'MSIE';   
        }   
        elseif (preg_match('/Firefox/i',$Browser)) {   
            $Browser = 'Firefox';   
        }   
        elseif (preg_match('/Chrome/i',$Browser)) {   
            $Browser = 'Chrome';   
        }   
        elseif (preg_match('/Safari/i',$Browser)) {   
            $Browser = 'Safari';   
        }   
        elseif (preg_match('/Opera/i',$Browser)) {   
            $Browser = 'Opera';   
        }   
        else {   
            $Browser = 'Other';   
        }   
        return $Browser;   
    }   
    function GetOS() {   
        $OS = $_SERVER['HTTP_USER_AGENT'];   
        if (preg_match('/win/i',$OS)) {   
            $OS = 'Windows';   
        }   
        elseif (preg_match('/mac/i',$OS)) {   
            $OS = 'MAC';   
        }   
        elseif (preg_match('/linux/i',$OS)) {   
            $OS = 'Linux';   
        }   
        elseif (preg_match('/unix/i',$OS)) {   
            $OS = 'Unix';   
        }   
        elseif (preg_match('/bsd/i',$OS)) {   
            $OS = 'BSD';   
        }   
        else {   
            $OS = 'Other';   
        }   
        return $OS;   
    }   
    function GetIP() {   
        if (!emptyempty($_SERVER['HTTP_CLIENT_IP'])) {   
        //如果变量是非空或非零的值,则 empty()返回 FALSE。   
            $IP = explode(',',$_SERVER['HTTP_CLIENT_IP']);   
        }   
        elseif (!emptyempty($_SERVER['HTTP_X_FORWARDED_FOR'])) {   
            $IP = explode(',',$_SERVER['HTTP_X_FORWARDED_FOR']);   
        }   
        elseif (!emptyempty($_SERVER['REMOTE_ADDR'])) {   
            $IP = explode(',',$_SERVER['REMOTE_ADDR']);   
        }   
        else {   
            $IP[0] = 'None';   
        }   
        return $IP[0];   
    }   
    private function GetAddIsp() {   
        $IP = $this->GetIP();   
        $AddIsp = mb_convert_encoding(file_get_contents('http://open.baidu.com/ipsearch/s?tn=ipjson&wd='.$IP),'UTF-8','GBK');   
        //mb_convert_encoding() 转换字符编码。   
        if (preg_match('/noresult/i',$AddIsp)) {   
            $AddIsp = 'None';   
        }   
        else {   
            $Sta = stripos($AddIsp,$IP) + strlen($IP) + strlen('来自');   
            $Len = stripos($AddIsp,'"}')-$Sta;   
            $AddIsp = substr($AddIsp,$Sta,$Len);   
        }   
        $AddIsp = explode(' ',$AddIsp);   
        return $AddIsp;   
    }   
    function GetAdd() {   
        $Add = $this->GetAddIsp();   
        return $Add[0];   
    }   
    function GetIsp() {   
        $Isp = $this->GetAddIsp();   
        if ($Isp[0] != 'None' && isset($Isp[1])) {   
            $Isp = $Isp[1];   
        }   
        else {   
            $Isp = 'None';   
        }   
        return $Isp;   
    }   
}   
?>  

代码二:

再发3个简化版的

该程序是在cli方式下运营的,在浏览器上应有也可以
php获取局域网中的用户ip功效就做到了,主要选取的是php的exec函数
和window的arp -a  命令
其间获得本机IP:gethostbyname($_ENV[‘COMPUTERNAME’])
有别于今后的写法,感兴趣的爱人能够承袭长远研商一下。
获取主机名函数:gethostbyaddr(IPd) 这几个函数功效也很强劲。

<?php
error_reporting (E_ERROR | E_WARNING | E_PARSE);
if($HTTP_SERVER_VARS["HTTP_X_FORWARDED_FOR"]){
$ip = $HTTP_SERVER_VARS["HTTP_X_FORWARDED_FOR"];
}
elseif($HTTP_SERVER_VARS["HTTP_CLIENT_IP"]){
$ip = $HTTP_SERVER_VARS["HTTP_CLIENT_IP"];
}
elseif ($HTTP_SERVER_VARS["REMOTE_ADDR"]){
$ip = $HTTP_SERVER_VARS["REMOTE_ADDR"];
}
elseif (getenv("HTTP_X_FORWARDED_FOR")){
$ip = getenv("HTTP_X_FORWARDED_FOR");
}
elseif (getenv("HTTP_CLIENT_IP")){
$ip = getenv("HTTP_CLIENT_IP");
}
elseif (getenv("REMOTE_ADDR")){
$ip = getenv("REMOTE_ADDR");
}
else{
$ip = "Unknown";
}
echo $ip;
?>
function getIpAddress(){  
  $ipContent  = file_get_contents("http://int.dpool.sina.com.cn/iplookup/iplookup.php?format=js");  
  $jsonData = explode("=",$ipContent);   
  $jsonAddress = substr($jsonData[1], 0, -1);  
  return $jsonAddress;  
}  
$ip_info=json_decode(getIpAddress());  

你大概感兴趣的稿子:

  • php利用微博接口查询ip获取地理地方示例
  • php读取qqwry.dat
    ip地址定位文件的类实例代码
  • PHP 获取ip地址代码汇总
  • PHP正确获取服务器IP地址的方法
  • php达成基于IP地址获取其所在省市的秘籍
  • PHP
    curl伪造IP地址和header消息代码实例
  • PHP
    获取客户端真实IP地址两种方法小结
  • PHP中依照IP地址剖断城市达成城市切换或跳转代码
  • php中获取远程客户端的实在ip地址的办法
  • php新浪乐乎登6接口用法实例
  • PHP接纳curl模仿用户登入知乎博客园发天涯论坛的方法
  • PHP基于和讯IP库获取IP详细地址的秘籍

发表评论

电子邮件地址不会被公开。 必填项已用*标注

网站地图xml地图