python3實現域名查詢和whois查詢

關鍵字:python3 域名查詢 域名查詢接口 whois查詢
原文:http://www.cnblogs.com/txw1958/archive/2012/08/31/python3-domain-whois.html html

1. 域名查詢
萬網提供了域名查詢接口,接口採用HTTP協議:
接口URL:http://panda.www.net.cn/cgi-bin/check.cgi
接口參數:area_domain,接口參數值爲標準域名,例:doucube.com
調用舉例:python

http://panda.www.net.cn/cgi-bin/check.cgi?area_domain=doucube.com

返回:服務器

  <?xml version="1.0" encoding="gb2312" ?> 
- <property>
  <returncode>200</returncode> 
  <key>doucube.com</key> 
  <original>211 : Domain name is not available</original> 
  </property>

返回結果說明:dom

<returncode>200</returncode> 返回碼,200表示返回成功
<key>doucube.com</key>  表示當前查詢的域名
<original>211 : Domain name is not available</original> 返回結果的原始信息,主要有如下幾種

original=210 : Domain name is available 表示域名能夠註冊 original=211 : Domain name is not available 表示域名已經註冊 original=212 : Domain name is invalid 表示查詢的域名無效 original=213 : Time out 查詢超時

 

用python3實現以下網站

 1.1 查詢已經被註冊的域名url

import urllib.request
req = urllib.request.urlopen('http://panda.www.net.cn/cgi-bin/check.cgi?area_domain=doucube.com')
print(req.read().decode())

返回結果:不可用,已經被註冊spa

<?xml version="1.0" encoding="gb2312" ?> 
- <property>
  <returncode>200</returncode> 
  <key>doucube.com</key> 
  <original>211 : Domain name is not available</original> 
  </property>

1.2 查詢沒有被註冊的域名.net

req2 = urllib.request.urlopen('http://panda.www.net.cn/cgi-bin/check.cgi?area_domain=doucube.net')
print(req2.read().decode())

返回結果:可用,未被註冊code

  <?xml version="1.0" encoding="gb2312" ?> 
- <property>
  <returncode>200</returncode> 
  <key>doucube.net</key> 
  <original>210 : Domain name is available</original> 
  </property>

1.3 查詢不存在的域名,使用不存在的後綴xml

req3 = urllib.request.urlopen('http://panda.www.net.cn/cgi-bin/check.cgi?area_domain=doucube.net2')
print(req3.read().decode())

返回結果:域名無效

  <?xml version="1.0" encoding="gb2312" ?> 
- <property>
  <returncode>200</returncode> 
  <key>doucube.net2</key> 
  <original>212 : Domain name is invalid</original> 
  </property>

 

2.whois查詢
因爲沒有找到像域名查詢接口那樣好的API,這裏直接抓取站長之家的whois查詢頁面(http://whois.chinaz.com/)

req_whois = urllib.request.urlopen('http://whois.chinaz.com/doucube.com')
print(req_whois.read().decode())

在返回的結果中有這樣一段html代碼,這段信息就是查詢的whois信息

<div style=" text-align:center;"> 
    <div class="div_whois">
        域名:doucube.com&nbsp;&nbsp;
        <a href='http://www.doucube.com' target=_blank>訪問此網站</a></div>
    <div id="whoisinfo" class="div_whois">
        註冊商:GODADDY.COM, LLC<br/>
        域名服務器:whois.godaddy.com<br/>
        DNS服務器:DNS1.FREEHOSTIA.COM<br/>
        DNS服務器:DNS2.FREEHOSTIA.COM<br/>
        域名狀態:運營商設置了客戶禁止刪除保護<br/>
        域名狀態:運營商設置了客戶禁止續費保護<br/>
        域名狀態:運營商設置了客戶禁止轉移保護<br/>
        域名狀態:運營商設置了客戶禁止修改保護<br/>
        更新時間:2012年05月28日<br/>
        建立時間:2012年05月23日<br/>
        過時時間:2013年05月23日<br/>
        聯繫人:zhu, alice<br/>
        聯繫方式:<img src="/displayemail.aspx?email=M8N8oc1O|iQhqGCDHdpH9m77v2qrQfW8"/>
        <br/>
        <br/>
    </div>
</div>
相關文章
相關標籤/搜索