Discuz教程网

用PHP实现标准的IP Whois查询

[复制链接]
authicon dly 发表于 2011-1-16 10:29:11 | 显示全部楼层 |阅读模式
由于Internet的历史原因,apin负责整个网络IP的整体规划以及北美区 还有部分非洲地区的IP分配管理,与此相应的是,whois.apin.net是IP whois的root server,标准的IP whois查询方法是,首先向whois.apin.net查询某个IP属于哪个大区,然后再向该区的whois 服务器查询此IP的whois详细信息。
目前负责 IPV4的大区
whois.arin.net 美洲区 北美
whois.apnic.net 亚太区 包括亚洲和澳大利亚
whois.ripe.net 欧洲区 欧洲/中东(西亚)/北非
whois.lacnic.net 拉美区 拉丁美洲和加勒比海区域
非洲网络的IP查询也在whois.arin.net
向某个whois服务器提交whois查询的过程
打开一个到whois服务器的43端口的连接,然后发送要查询的域名 和一个回车换行。如果要查询多个域名,请用空格分开然后从sokect中读取结果。最后服务器将自动断开连接。
用PHP实现
1.验证IP(用 ip2long代替 ereg)
2.向 whois.arin.net查询,如果数据库中没有相关信息,会给出一个Referral Server的URL,格式如下
ReferralServer:
然后根据此信息,继续查询
代码如下
whoisip.php

  1. <?php
  2. include_once "lang.inc.php";
  3. $IP = isset($_GET[\'ip\'])?$_GET[\'ip\']:\'blank\';
  4. if (-1 === ip2long($ip))
  5. die(str_replace(\'%IP%\', $IP, $Text[\'ip_invalid\']));
  6. echo GetWhois($IP);
  7. function GetWhois($IP)
  8. {
  9. global $Text;
  10. $rootwhois = \'whois.arin.net\';
  11. $buffer = str_replace(\'%SERVER%\', $rootwhois, $Text[\'sock_connect\']);
  12. $buffer1 = ReadSocket($rootwhois,$IP);
  13. if ($buffer1 !== \'\')
  14. {
  15. $whois = SubStrByTag("ReferralServer: whois://","\\n",$buffer1);
  16. //remove port number ":43";
  17. if ( ($pos=strpos($whois,":")) !== FALSE)
  18. {
  19. $whois = substr($whois, 0,$pos);
  20. }
  21. if ($whois !== \'\')
  22. {
  23. $buffer .= str_replace(\'%SERVER%\', $whois, $Text[\'sock_connect\']);
  24. $buffer .= ReadSocket($whois,$IP);
  25. }
  26. else
  27. {
  28. $buffer .= $buffer1;
  29. }
  30. }
  31. return nl2br($buffer);
  32. }
  33. function SubStrByTag($firstTag,$secondTag,&$longStr)
  34. {
  35. $firstPos = strpos ($longStr,$firstTag);
  36. $ret = \'\';
  37. if ($firstPos !== FALSE)
  38. {
  39. $secondPos = strpos ($longStr,$secondTag,$firstPos);
  40. if ($secondPos !== FALSE)
  41. {
  42. $firstPos += strlen($firstTag);
  43. $ret = substr($longStr,$firstPos,$secondPos-$firstPos);
  44. }
  45. }
  46. return $ret;
  47. }
  48. function ReadSocket($whois,$ip)
  49. {
  50. global $Text;
  51. $buffer = \'\';
  52. if (!$sock = fsockopen( $whois, 43, $errNum, $errStr, 20))
  53. {
  54. $buffer = str_replace(\'%SERVER%\', $whois, $Text[\'sock_fail\']);
  55. }
  56. else
  57. {
  58. fputs($sock,"$ip\\n");
  59. //$buffer = fread($sock, 8192);
  60. while(!feof($sock)) $buffer.=fgets($sock, 8192);
  61. fclose($sock);
  62. }
  63. return $buffer;
  64. }
  65. ?>
复制代码

语言文件:
lang.inc.php

  1. <?php
  2. $Text = Array(
  3. \'ip_invalid\'=>\'I want to get a valid IP, but it is [%IP%].\',
  4. \'sock_connect\'=>\'Ask %SERVER% ...
  5. \',
  6. \'sock_fail\'=>\'Cannot connect to the host:%SERVER%\'
  7. );
  8. ?>
复制代码

其他有名的whois服务器
1.Tucows (whois.opensrs.net) 一次只能一个连接
dnsstuff就是查询的它
2.BulkRegister (whois.bulkregiter.net) 小心它临时封IP,如果大量连接的话
3.Network Solutions (whois.networksolutions.com) 一天只能查1000次
4.Go Daddy (whois.godaddy.com)
5.whois.abuse.net





上一篇:PHP获取服务器端信息
下一篇:利用Yahoo Search API开发自已的搜索引擎-php版
authicon D_hong 发表于 2011-5-10 06:59:52 | 显示全部楼层
好辛苦才找到啊
authicon 纤陌陌 发表于 2011-5-14 08:59:53 | 显示全部楼层
顶啦,不错吧
authicon fhiejkl 发表于 2011-5-15 22:59:47 | 显示全部楼层
好辛苦才找到啊
authicon 月之海洋 发表于 2011-6-18 10:00:00 | 显示全部楼层
顶的就是你
authicon nancybingling 发表于 2011-6-25 00:59:50 | 显示全部楼层
真的有意思!
authicon fantuanzi 发表于 2011-6-25 22:00:00 | 显示全部楼层
看看  好像不错
authicon 蓝色天空k 发表于 2011-6-25 22:59:47 | 显示全部楼层
前来看看那
authicon 82xiaochong911 发表于 2011-6-27 22:00:44 | 显示全部楼层
不错,我喜欢
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

1314学习网 ( 浙ICP备10214163号 )

GMT+8, 2025-5-2 07:04

Powered by Discuz! X3.4

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表