查找正在访问该站点的计算机的主机名

时间:2019-06-21 17:05:55

标签: php

我正在尝试将访问该站点的设备的名称插入数据库。

要找到ip,我可以这样操作:

$teste3 = $_SERVER["REMOTE_ADDR"];

要找出计算机的主机名,我需要执行以下操作:

$hostname = gethostbyaddr($teste3);

但是重新输入计算机的IP而不是计算机的主机名。

问题更新:

我的网络中的IP由活动目录分配。没有在活动目录中注册设备的ip和主机名。 有没有办法通过php中的dns获取主机名?

2 个答案:

答案 0 :(得分:0)

您正在寻找的是:gethostbyaddr

示例:

echo gethostbyaddr($_SERVER['REMOTE_ADDR']);

输出: host.example.com

编辑: 第一个解决方案似乎对您不起作用。这是实际执行反向请求的肮脏方法。反向请求是:

  1. 八位字节从IP反转
  2. 追加.in-addr.arpa
  3. PTR请求。

您可以通过dns_get_record()请求执行此操作 这是一个应该起作用的小脚本:

$remote_ip = $_SERVER['REMOTE_ADDR'];
$ip_array = explode(".", $remote_ip);

$reverse_ip_array = array_reverse($ip_array);
foreach ($reverse_ip_array as &$octet) {
    $request .= $octet;
    $request .= ".";
}

$request .= "in-addr.arpa";
$result_array = dns_get_record($request, DNS_PTR);


所以现在它存储了一个数组;

array(1) {
  [0] => array(5) {
    ["host"] => string(22) "1.0.0.127.in-addr.arpa" 
    ["class"] => string(2) "IN" 
    ["ttl"] => int(120)
    ["type"] => string(3) "PTR" 
    ["target"] => string(9) "localhost"
  }
}

因此,现在您可以使用isset()

来验证数组是否在代码中正确构建。

然后,您可以对目标执行任何操作: echo $result_array[0]["target"]) 输出localhost

答案 1 :(得分:0)

我使用'NTLM:

$headers = apache_request_headers();
      if (!isset($headers['Authorization'])){
         header('HTTP/1.1 401 Unauthorized');
         header('WWW-Authenticate: NTLM');
         exit;
      }

$auth = $headers['Authorization'];
if (substr($auth,0,5) == 'NTLM ') {
  $msg = base64_decode(substr($auth, 5));
  if (substr($msg, 0, 8) != "NTLMSSP\x00")
    die('error header not recognised');
  if ($msg[8] == "\x01") {
    $msg2 = "NTLMSSP\x00\x02\x00\x00\x00".
        "\x00\x00\x00\x00". // target name len/alloc
      "\x00\x00\x00\x00". // target name offset
      "\x01\x02\x81\x00". // flags
      "\x00\x00\x00\x00\x00\x00\x00\x00". // challenge
      "\x00\x00\x00\x00\x00\x00\x00\x00". // context
      "\x00\x00\x00\x00\x00\x00\x00\x00"; // target info len/alloc/offset
    header('HTTP/1.1 401 Unauthorized');
    header('WWW-Authenticate: NTLM '.trim(base64_encode($msg2)));
    exit;
  }
  else if ($msg[8] == "\x03") {
    function get_msg_str($msg, $start, $unicode = true) {
      $len = (ord($msg[$start+1]) * 256) + ord($msg[$start]);
      $off = (ord($msg[$start+5]) * 256) + ord($msg[$start+4]);
      if ($unicode)
        return str_replace("\0", '', substr($msg, $off, $len));
      else
        return substr($msg, $off, $len);
    }
    $user = get_msg_str($msg, 36);
    $domain = get_msg_str($msg, 28);
    $workstation = get_msg_str($msg, 44);
  }
}