Whois 简单来说,就是一个用来查询域名是否已经被注册,以及注册域名的详细信息的数据库(如域名所有人、域名注册商、域名注册日期和过期日期等)。通过域名Whois服务器查询,可以查询域名归属者联系方式,以及注册和到期时间。通常情况下,whois信息均为真实信息,通过whois信息可以找到域名注册人的很多真实信息,像电话,邮箱,NS记录,是对网站进行社工非常好的信息来源,对于安全从业人员来说,快速获取whois信息,能够帮助自己掌握目标网站的很多有用信息。

而whois信息通常是保存在各级域名注册机构中,平常我们要查询whois信息都是通过godaddy、name.com、万网、新网等域名注册商网站通过查询页面提交域名进行查询,既慢又不能批量查询,太费劲了,这里我就把我珍藏很久的一个PS function贡献给大家,这个脚本支持140多种后缀的域名进行查询,尤其是一些生僻的域,找一个能支持这个域注册的注册商就不容易了,现在你不需要再为这个事情发愁了。

老规矩,先上代码,然后对关键操作进行解释:

  1. =====文件名:Get-whois.ps1=====
  2. function Get-WhoIs {
  3. <# Author:fuhj(powershell#live.cn ,http://fuhaijun.com)
  4. # Does a raw WHOIS query and returns the results
  5. # The simplest whois search
  6. #.Example
  7. # get-whois dnspod.com
  8. #
  9. # This example is one that forwards to a second whois server ...
  10. #.Example
  11. # get-whois baidu.com -NoForward
  12. #
  13. # Returns the partial results you get when you don't follow forwarding to a new whois server
  14. # get-whois n 128.11.5.98 -server whois.arin.net
  15. #
  16. # Does an ip lookup at arin.net
  17. #>
  18.  
  19. [CmdletBinding()]
  20. param(
  21. # The query to send to WHOIS servers
  22. [Parameter(Position=0, ValueFromRemainingArguments=$true)]
  23. [string]$query,
  24.  
  25. # A specific whois server to search
  26. [string]$server,
  27.  
  28. # Disable forwarding to new whois servers
  29. [switch]$NoForward
  30. )
  31. end {
  32. $TLDs = DATA {
  33. @{
  34.  
  35. ".com"= "whois.verisign-grs.com","whois.crsnic.net"
  36. ".net"= "whois.verisign-grs.com","whois.crsnic.net"
  37. ".org"= "whois.pir.org","whois.publicinterestregistry.net"
  38. ".info"= "whois.afilias.info","whois.afilias.net"
  39. ".biz"= "whois.neulevel.biz"
  40. ".us"= "whois.nic.us"
  41. ".uk"= "whois.nic.uk"
  42. ".ca"= "whois.cira.ca"
  43. ".tel"= "whois.nic.tel"
  44. ".ie"= "whois.iedr.ie","whois.domainregistry.ie"
  45. ".it"= "whois.nic.it"
  46. ".li"= "whois.nic.li"
  47. ".no"= "whois.norid.no"
  48. ".cc"= "whois.nic.cc"
  49. ".eu"= "whois.eu"
  50. ".nu"= "whois.nic.nu"
  51. ".au"= "whois.aunic.net","whois.ausregistry.net.au"
  52. ".de"= "whois.denic.de"
  53. ".ws"= "whois.worldsite.ws","whois.nic.ws","www.nic.ws"
  54. ".sc"= "whois2.afilias-grs.net"
  55. ".mobi" = "whois.dotmobiregistry.net"
  56. ".pro"= "whois.registrypro.pro","whois.registry.pro"
  57. ".edu"= "whois.educause.net","whois.crsnic.net"
  58. ".tv"= "whois.nic.tv","tvwhois.verisign-grs.com"
  59. ".travel" = "whois.nic.travel"
  60. ".name" = "whois.nic.name"
  61. ".in"= "whois.inregistry.net","whois.registry.in"
  62. ".me"= "whois.nic.me","whois.meregistry.net"
  63. ".at"= "whois.nic.at"
  64. ".be"= "whois.dns.be"
  65. ".cn"= "whois.cnnic.cn","whois.cnnic.net.cn"
  66. ".edu.cn"="whois.edu.cn"
  67. ".asia"= "whois.nic.asia"
  68. ".ru"= "whois.ripn.ru","whois.ripn.net"
  69. ".ro"= "whois.rotld.ro"
  70. ".aero" = "whois.aero"
  71. ".fr"= "whois.nic.fr"
  72. ".se"= "whois.iis.se","whois.nic-se.se","whois.nic.se"
  73. ".nl"= "whois.sidn.nl","whois.domain-registry.nl"
  74. ".nz"= "whois.srs.net.nz","whois.domainz.net.nz"
  75. ".mx"= "whois.nic.mx"
  76. ".tw"= "whois.apnic.net","whois.twnic.net.tw"
  77. ".ch"= "whois.nic.ch"
  78. ".hk"= "whois.hknic.net.hk"
  79. ".ac"= "whois.nic.ac"
  80. ".ae"= "whois.nic.ae"
  81. ".af"= "whois.nic.af"
  82. ".ag"= "whois.nic.ag"
  83. ".al"= "whois.ripe.net"
  84. ".am"= "whois.amnic.net"
  85. ".as"= "whois.nic.as"
  86. ".az"= "whois.ripe.net"
  87. ".ba"= "whois.ripe.net"
  88. ".bg"= "whois.register.bg"
  89. ".bi"= "whois.nic.bi"
  90. ".bj"= "www.nic.bj"
  91. ".br"= "whois.nic.br"
  92. ".br.com"="whois.centralnic.net"
  93. ".eu.org"="whois.eu.org"
  94. ".bt"= "whois.netnames.net"
  95. ".by"= "whois.ripe.net"
  96. ".bz"= "whois.belizenic.bz"
  97. ".cd"= "whois.nic.cd"
  98. ".ck"= "whois.nic.ck"
  99. ".cl"= "nic.cl"
  100. ".coop"= "whois.nic.coop"
  101. ".cx"= "whois.nic.cx"
  102. ".cy"= "whois.ripe.net"
  103. ".cz"= "whois.nic.cz"
  104. ".dk"= "whois.dk-hostmaster.dk"
  105. ".dm"= "whois.nic.cx"
  106. ".dz"= "whois.ripe.net"
  107. ".ee"= "whois.eenet.ee"
  108. ".eg"= "whois.ripe.net"
  109. ".es"= "whois.ripe.net"
  110. ".fi"= "whois.ficora.fi"
  111. ".fo"= "whois.ripe.net"
  112. ".gb"= "whois.ripe.net"
  113. ".ge"= "whois.ripe.net"
  114. ".gl"= "whois.ripe.net"
  115. ".gm"= "whois.ripe.net"
  116. ".gov"= "whois.nic.gov"
  117. ".gr"= "whois.ripe.net"
  118. ".gs"= "whois.adamsnames.tc"
  119. ".hm"= "whois.registry.hm"
  120. ".hn"= "whois2.afilias-grs.net"
  121. ".hr"= "whois.ripe.net"
  122. ".hu"= "whois.ripe.net"
  123. ".il"= "whois.isoc.org.il"
  124. ".int"= "whois.isi.edu"
  125. ".iq"= "vrx.net"
  126. ".ir"= "whois.nic.ir"
  127. ".is"= "whois.isnic.is"
  128. ".je"= "whois.je"
  129. ".jp"= "whois.jprs.jp"
  130. ".kg"= "whois.domain.kg"
  131. ".kr"= "whois.nic.or.kr"
  132. ".la"= "whois2.afilias-grs.net"
  133. ".lt"= "whois.domreg.lt"
  134. ".lu"= "whois.restena.lu"
  135. ".lv"= "whois.nic.lv"
  136. ".ly"= "whois.lydomains.com"
  137. ".ma"= "whois.iam.net.ma"
  138. ".mc"= "whois.ripe.net"
  139. ".md"= "whois.nic.md"
  140. ".mil"= "whois.nic.mil"
  141. ".mk"= "whois.ripe.net"
  142. ".ms"= "whois.nic.ms"
  143. ".mt"= "whois.ripe.net"
  144. ".mu"= "whois.nic.mu"
  145. ".my"= "whois.mynic.net.my"
  146. ".nf"= "whois.nic.cx"
  147. ".pl"= "whois.dns.pl"
  148. ".pr"= "whois.nic.pr"
  149. ".pt"= "whois.dns.pt"
  150. ".sa"= "saudinic.net.sa"
  151. ".sb"= "whois.nic.net.sb"
  152. ".sg"= "whois.nic.net.sg"
  153. ".sh"= "whois.nic.sh"
  154. ".si"= "whois.arnes.si"
  155. ".sk"= "whois.sk-nic.sk"
  156. ".sm"= "whois.ripe.net"
  157. ".st"= "whois.nic.st"
  158. ".su"= "whois.ripn.net"
  159. ".tc"= "whois.adamsnames.tc"
  160. ".tf"= "whois.nic.tf"
  161. ".th"= "whois.thnic.net"
  162. ".tj"= "whois.nic.tj"
  163. ".tk"= "whois.nic.tk"
  164. ".tl"= "whois.domains.tl"
  165. ".tm"= "whois.nic.tm"
  166. ".tn"= "whois.ripe.net"
  167. ".to"= "whois.tonic.to"
  168. ".tp"= "whois.domains.tl"
  169. ".tr"= "whois.nic.tr"
  170. ".ua"= "whois.ripe.net"
  171. ".uy"= "nic.uy"
  172. ".uz"= "whois.cctld.uz"
  173. ".va"= "whois.ripe.net"
  174. ".vc"= "whois2.afilias-grs.net"
  175. ".ve"= "whois.nic.ve"
  176. ".vg"= "whois.adamsnames.tc"
  177. ".yu"= "whois.ripe.net"
  178. }
  179. }
  180.  
  181. $EAP, $ErrorActionPreference = $ErrorActionPreference, "Stop"
  182.  
  183. $query = $query.Trim()
  184.  
  185. if($query -match "(?:\d{1,3}\.){3}\d{1,3}") {
  186. Write-Verbose "IP Lookup!"
  187. if($query -notmatch " ") {
  188. $query = "n $query"
  189. }
  190. if(!$server) { $server = "whois.arin.net" }
  191. } elseif(!$server) {
  192. $server = $TLDs.GetEnumerator() |
  193. Where { $query -like ("*"+$_.name) } |
  194. Select -Expand Value | Get-Random
  195. }
  196.  
  197. if(!$server) { $server = "whois.arin.net" }
  198. $maxRequery = 3
  199.  
  200. do {
  201. Write-Verbose "Connecting to $server"
  202. $client = New-Object System.Net.Sockets.TcpClient $server, 43
  203.  
  204. try {
  205. $stream = $client.GetStream()
  206.  
  207. Write-Verbose "Sending Query: $query"
  208. $data = [System.Text.Encoding]::Ascii.GetBytes( $query + "`r`n" )
  209. $stream.Write($data, 0, $data.Length)
  210.  
  211. Write-Verbose "Reading Response:"
  212. $reader = New-Object System.IO.StreamReader $stream, [System.Text.Encoding]::ASCII
  213.  
  214. $result = $reader.ReadToEnd()
  215.  
  216. if($result -match "(?s)Whois Server:\s*(\S+)\s*") {
  217. Write-Warning "Recommended WHOIS server: ${server}"
  218. if(!$NoForward) {
  219. Write-verbose "Non-Authoritative Results:`n${result}"
  220. # cache, in case we can't get an answer at the forwarder
  221. if(!$cachedResult) {
  222. $cachedResult = $result
  223. $cachedServer = $server
  224. }
  225. $server = $matches[1]
  226. $query = ($query -split " ")[-1]
  227. $maxRequery--
  228. } else { $maxRequery = 0 }
  229. } else { $maxRequery = 0 }
  230. } finally {
  231. if($stream) {
  232. $stream.Close()
  233. $stream.Dispose()
  234. }
  235. }
  236. } while ($maxRequery -gt 0)
  237.  
  238. $result
  239.  
  240. if($cachedResult -and ($result -split "`n").count -lt 5) {
  241. Write-Warning "Original Result from ${cachedServer}:"
  242. $cachedResult
  243. }
  244.  
  245. $ErrorActionPreference = $EAP
  246. }
  247. }

函数里定义了三个参数,两个[string]类型,一个[switch]类型,分别用于接收要进行whois查询的域名,指定whois域名服务器,以及是否允许将查询请求转发到其他域名解析服务器。随后创建了一个枚举值的哈希表,目的是用于存储不同域名后缀和whois服务器的对应关系,因为不同的域名后缀对应的域名信息是存储在不同的服务器上的。需要强调的是像.com、.net、.org、.info这几个注册量特别大的域名后缀指定了多个whois服务器,避免查询量过大无法有效返回结果的问题。

接下来通过New-Object创建一个System.Net.Sockets.TcpClient的TCP对象,连接上面指定的whois服务器的43端口用于查询whois信息,在通过一个System.IO.StreamReader对象接收whois信息返回的数据,并对数据进行解析。除此之外再加上try{}cache{}finally{}进行容错处理,在数据解析是也用到了正则表达式用于匹配目标字符串。

程序的运行方法有如下四种:

get-whois dnspod.com

先看看dnspod在被腾讯收购后有没有更改whois信息,貌似鹅厂没有改过

get-whois jd.com –NoForward

get-whois n 128.11.5.98 -server whois.arin.net

 

 

作者: 付海军

出处:http://fuhj02.cnblogs.com

版权:本文版权归作者和博客园共有

转载:欢迎转载,为了保存作者的创作热情,请按要求【转载】,谢谢

要求:未经作者同意,必须保留此段声明;必须在文章中给出原文连接;否则必究法律责任

个人网站: http://www.fuhaijun.com/

通过PowerShell获取域名whois信息的更多相关文章

  1. GDPR或使全球域名whois信息被隐藏

    什么是GDPR? GDPR 全称为 General Data Protection Regulation,是欧盟 2016 年 4 月通过的一项通用数据保护条例(或称“一般数据保护法案”),是 199 ...

  2. Powershell 获取文件版本信息

    获取文件版本信息,通过FileVersionInfo::GetVersioninfo(file) 来获取信息 function Check-DdpstoreFileVersion{ $Ddpstore ...

  3. C# 利用Powershell获取网络相关信息

    利用Get-NetAdapter获取信息 Get-NetAdapter 参考链接:https://docs.microsoft.com/en-us/powershell/module/netadapt ...

  4. Powershell - 获取OS版本信息和catpion信息

    Environment  获取 OSversion: $OSVersion = [System.Environment]::OSVersion.Version WMI获取Caption: $OSCap ...

  5. php 获取域名的whois 信息

    首先先了解几个文件操作函数: fwrite() 函数写入文件(可安全用于二进制文件). fwrite() 把 string 的内容写入文件指针 file 处. 如果指定了 length,当写入了 le ...

  6. JS获取链接中域名等信息

    以访问百度为例子http://pan.baidu.com/share/qrcode?w=150&h=150&url=http%3A%2F%2F172.16.1.96%2FWeb%2FG ...

  7. 使用PowerShell 获取azure image publisher offer sku 信息

    使用azure powershell 获取指定区域的可用镜像 publisher offer sku信息 param ( [parameter(Mandatory = $false)] $Locati ...

  8. # Linux Whois3获取 运营商信息

    Linux Whois3获取 运营商信息 APNIC是管理亚太地区IP地址分配的机构,它有着丰富准确的IP地址分配库,同时这些信息也是对外公开的,并提供了一个查询工具,下面就让我们看看如何在Linux ...

  9. 通过PowerShell获取Windows系统密码Hash

    当你拿到了系统控制权之后如何才能更长的时间内控制已经拿到这台机器呢?作为白帽子,已经在对手防线上撕开一个口子,如果你需要进一步扩大战果,你首先需要做的就是潜伏下来,收集更多的信息便于你判断,便于有更大 ...

随机推荐

  1. 蛙蛙推荐:如何实时监控MySql状态

    大多网站的性能瓶颈都会出在数据库上,所以想把Mysql监控起来,就搜索了下相关资料. 后来和同事讨论了下cacti和nagios有些老套和过时,graphite比较时尚,然后就搜了下相关的资料,最后搞 ...

  2. 用c#开发微信 (22) 微信商城 - 微信支付 (c#源码)

    微信支付有几种支付模式:刷卡支付,扫码支付,公众号支付,APP支付.本文介绍用于在微信商城里的公众号支付. 1. 效果图 在商城里购买商品后,到支付页面: 点击上面的确认支付,转到下面微信支付页面: ...

  3. Linux上成功编译CoreCLR源代码

    >>Build日期:2015-2-5下午(编译失败). 开始Linux发行版用的是CentOS 6.5,操作步骤: 1)配置git: git config --global http.ss ...

  4. javascript中的call()和apply()方法的使用

    1.方法定义 call方法: 语法:call([thisObj[,arg1[, arg2[,   [,.argN]]]]]) 定义:调用一个对象的一个方法,以另一个对象替换当前对象. 说明: call ...

  5. spring MVC注解深入研究

    @Controller @Service  @Controller和 @Component注册一个action 到spring 上下文中,bean 的ID 默认为类名称开头字母小写.@Reposito ...

  6. 在express站点中使用ejs模板引擎

    在express站点中使用ejs模板引擎 文/玄魂 目录 在express站点中使用ejs模板引擎 前言 1.1         安装 1.2修改app.js 1.3创建测试页面 前言 使用 vs创建 ...

  7. 团队作业—第二周—SRS

    一.系统整体用例图: 二.用户用例图: 三.医院用例图:

  8. ActiveMQ第五弹:增加ReDelivery功能

    在使用Message Queue的过程中,总会由于种种原因而导致消息失败.一个经典的场景是一个生成者向Queue中发消息,里面包含了一组邮件地址和邮件内容.而消费者从Queue中将消息一条条读出来,向 ...

  9. Sharing count on Facebook, Twitter, and LinkedIn

    最近一段时间一直在研究有关Social Network的东西,这里有几个在当前国外主流社交网站上用来显示分享数量的API,记录一下,今后可能会用得着. Facebook Facebook将FQL(Fa ...

  10. Django站点管理--ModelAdmin

    class AuthorAdmin(admin.ModelAdmin): list_display=('name', 'age', 'sex') #指定要显示的字段 search_fields=('n ...