• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    PowerShell小技巧之获取域名whois信息

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

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

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

    =====文件名:Get-whois.ps1=====
     function Get-WhoIs {
    # Author:fuhj(powershell#live.cn ,http://fuhaijun.com) 
      # Does a raw WHOIS query and returns the results
      #  The simplest whois search
      #.Example
      #  get-whois dnspod.com
      #
      #  This example is one that forwards to a second whois server ...
      #.Example
      #  get-whois baidu.com -NoForward
      #
      #  Returns the partial results you get when you don't follow forwarding to a new whois server
      #  get-whois n 128.11.5.98 -server whois.arin.net
      #
      #  Does an ip lookup at arin.net
      #>
    
      [CmdletBinding()]
      param(
        # The query to send to WHOIS servers
        [Parameter(Position=0, ValueFromRemainingArguments=$true)]
        [string]$query,
    
        # A specific whois server to search
        [string]$server,
    
        # Disable forwarding to new whois servers
        [switch]$NoForward
      )
      end {
        $TLDs = DATA {
         @{
    
          ".com"= "whois.verisign-grs.com","whois.crsnic.net"
          ".net"= "whois.verisign-grs.com","whois.crsnic.net"
          ".org"= "whois.pir.org","whois.publicinterestregistry.net"
          ".info"= "whois.afilias.info","whois.afilias.net"
          ".biz"= "whois.neulevel.biz"
          ".us"= "whois.nic.us"
          ".uk"= "whois.nic.uk"
          ".ca"= "whois.cira.ca"
          ".tel"= "whois.nic.tel"
          ".ie"= "whois.iedr.ie","whois.domainregistry.ie"
          ".it"= "whois.nic.it"
          ".li"= "whois.nic.li"
          ".no"= "whois.norid.no"
          ".cc"= "whois.nic.cc"
          ".eu"= "whois.eu"
          ".nu"= "whois.nic.nu"
          ".au"= "whois.aunic.net","whois.ausregistry.net.au"
          ".de"= "whois.denic.de"
          ".ws"= "whois.worldsite.ws","whois.nic.ws","www.nic.ws"
          ".sc"= "whois2.afilias-grs.net"
          ".mobi" = "whois.dotmobiregistry.net"
          ".pro"= "whois.registrypro.pro","whois.registry.pro"
          ".edu"= "whois.educause.net","whois.crsnic.net"
          ".tv"= "whois.nic.tv","tvwhois.verisign-grs.com"
          ".travel"  = "whois.nic.travel"
          ".name" = "whois.nic.name"
          ".in"= "whois.inregistry.net","whois.registry.in"
          ".me"= "whois.nic.me","whois.meregistry.net"
          ".at"= "whois.nic.at"
          ".be"= "whois.dns.be"
          ".cn"= "whois.cnnic.cn","whois.cnnic.net.cn"
          ".edu.cn"="whois.edu.cn"
          ".asia"= "whois.nic.asia"
          ".ru"= "whois.ripn.ru","whois.ripn.net"
          ".ro"= "whois.rotld.ro"
          ".aero" = "whois.aero"
          ".fr"= "whois.nic.fr"
          ".se"= "whois.iis.se","whois.nic-se.se","whois.nic.se"
          ".nl"= "whois.sidn.nl","whois.domain-registry.nl"
          ".nz"= "whois.srs.net.nz","whois.domainz.net.nz"
          ".mx"= "whois.nic.mx"
          ".tw"= "whois.apnic.net","whois.twnic.net.tw"
          ".ch"= "whois.nic.ch"
          ".hk"= "whois.hknic.net.hk"
          ".ac"= "whois.nic.ac"
          ".ae"= "whois.nic.ae"
          ".af"= "whois.nic.af"
          ".ag"= "whois.nic.ag"
          ".al"= "whois.ripe.net"
          ".am"= "whois.amnic.net"
          ".as"= "whois.nic.as"
          ".az"= "whois.ripe.net"
          ".ba"= "whois.ripe.net"
          ".bg"= "whois.register.bg"
          ".bi"= "whois.nic.bi"
          ".bj"= "www.nic.bj"
          ".br"= "whois.nic.br"
          ".br.com"="whois.centralnic.net"
          ".eu.org"="whois.eu.org"
          ".bt"= "whois.netnames.net"
          ".by"= "whois.ripe.net"
          ".bz"= "whois.belizenic.bz"
          ".cd"= "whois.nic.cd"
          ".ck"= "whois.nic.ck"
          ".cl"= "nic.cl"
          ".coop"= "whois.nic.coop"
          ".cx"= "whois.nic.cx"
          ".cy"= "whois.ripe.net"
          ".cz"= "whois.nic.cz"
          ".dk"= "whois.dk-hostmaster.dk"
          ".dm"= "whois.nic.cx"
          ".dz"= "whois.ripe.net"
          ".ee"= "whois.eenet.ee"
          ".eg"= "whois.ripe.net"
          ".es"= "whois.ripe.net"
          ".fi"= "whois.ficora.fi"
          ".fo"= "whois.ripe.net"
          ".gb"= "whois.ripe.net"
          ".ge"= "whois.ripe.net"
          ".gl"= "whois.ripe.net"
          ".gm"= "whois.ripe.net"
          ".gov"= "whois.nic.gov"
          ".gr"= "whois.ripe.net"
          ".gs"= "whois.adamsnames.tc"
          ".hm"= "whois.registry.hm"
          ".hn"= "whois2.afilias-grs.net"
          ".hr"= "whois.ripe.net"
          ".hu"= "whois.ripe.net"
          ".il"= "whois.isoc.org.il"
          ".int"= "whois.isi.edu"
          ".iq"= "vrx.net"
          ".ir"= "whois.nic.ir"
          ".is"= "whois.isnic.is"
          ".je"= "whois.je"
          ".jp"= "whois.jprs.jp"
          ".kg"= "whois.domain.kg"
          ".kr"= "whois.nic.or.kr"
          ".la"= "whois2.afilias-grs.net"
          ".lt"= "whois.domreg.lt"
          ".lu"= "whois.restena.lu"
          ".lv"= "whois.nic.lv"
          ".ly"= "whois.lydomains.com"
          ".ma"= "whois.iam.net.ma"
          ".mc"= "whois.ripe.net"
          ".md"= "whois.nic.md"
          ".mil"= "whois.nic.mil"
          ".mk"= "whois.ripe.net"
          ".ms"= "whois.nic.ms"
          ".mt"= "whois.ripe.net"
          ".mu"= "whois.nic.mu"
          ".my"= "whois.mynic.net.my"
          ".nf"= "whois.nic.cx"
          ".pl"= "whois.dns.pl"
          ".pr"= "whois.nic.pr"
          ".pt"= "whois.dns.pt"
          ".sa"= "saudinic.net.sa"
          ".sb"= "whois.nic.net.sb"
          ".sg"= "whois.nic.net.sg"
          ".sh"= "whois.nic.sh"
          ".si"= "whois.arnes.si"
          ".sk"= "whois.sk-nic.sk"
          ".sm"= "whois.ripe.net"
          ".st"= "whois.nic.st"
          ".su"= "whois.ripn.net"
          ".tc"= "whois.adamsnames.tc"
          ".tf"= "whois.nic.tf"
          ".th"= "whois.thnic.net"
          ".tj"= "whois.nic.tj"
          ".tk"= "whois.nic.tk"
          ".tl"= "whois.domains.tl"
          ".tm"= "whois.nic.tm"
          ".tn"= "whois.ripe.net"
          ".to"= "whois.tonic.to"
          ".tp"= "whois.domains.tl"
          ".tr"= "whois.nic.tr"
          ".ua"= "whois.ripe.net"
          ".uy"= "nic.uy"
          ".uz"= "whois.cctld.uz"
          ".va"= "whois.ripe.net"
          ".vc"= "whois2.afilias-grs.net"
          ".ve"= "whois.nic.ve"
          ".vg"= "whois.adamsnames.tc"
          ".yu"= "whois.ripe.net"
         }
        }
    
        $EAP, $ErrorActionPreference = $ErrorActionPreference, "Stop"
    
        $query = $query.Trim()
    
        if($query -match "(?:\d{1,3}\.){3}\d{1,3}") {
          Write-Verbose "IP Lookup!"
          if($query -notmatch " ") {
            $query = "n $query"
          }
          if(!$server) { $server = "whois.arin.net" }
        } elseif(!$server) {
          $server = $TLDs.GetEnumerator() |
            Where { $query -like ("*"+$_.name) } |
            Select -Expand Value | Get-Random
        }
    
        if(!$server) { $server = "whois.arin.net" }
        $maxRequery = 3 
    
        do {
          Write-Verbose "Connecting to $server"
          $client = New-Object System.Net.Sockets.TcpClient $server, 43
    
          try {
            $stream = $client.GetStream()
    
            Write-Verbose "Sending Query: $query"
            $data = [System.Text.Encoding]::Ascii.GetBytes( $query + "`r`n" )
            $stream.Write($data, 0, $data.Length)
    
            Write-Verbose "Reading Response:"
            $reader = New-Object System.IO.StreamReader $stream, [System.Text.Encoding]::ASCII
    
            $result = $reader.ReadToEnd()
    
            if($result -match "(?s)Whois Server:\s*(\S+)\s*") {
              Write-Warning "Recommended WHOIS server: ${server}"
              if(!$NoForward) {
                Write-verbose "Non-Authoritative Results:`n${result}"
                # cache, in case we can't get an answer at the forwarder
                if(!$cachedResult) {
                  $cachedResult = $result
                  $cachedServer = $server
                }
                $server = $matches[1]
                $query = ($query -split " ")[-1]
                $maxRequery--
              } else { $maxRequery = 0 }
            } else { $maxRequery = 0 }
          } finally {
            if($stream) {
              $stream.Close()
              $stream.Dispose()
            }
          }
        } while ($maxRequery -gt 0)
    
        $result
    
        if($cachedResult -and ($result -split "`n").count -lt 5) {
          Write-Warning "Original Result from ${cachedServer}:"
          $cachedResult
        }
    
        $ErrorActionPreference = $EAP
      }
     }

    函数里定义了三个参数,两个[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

     

    您可能感兴趣的文章:
    • PowerShell小技巧之获取Windows系统密码Hash
    • PowerShell小技巧之实现文件下载(类wget)
    • PowerShell小技巧之定时抓取屏幕图像
    • PowerShell小技巧之定时记录操作系统行为
    • PowerShell小技巧之读取Windows产品密钥
    • PowerShell小技巧之发送TCP请求
    • PowerShell小技巧之尝试ssh登录
    • PowerShell小技巧之执行SOAP请求
    • PowerShell脚本开发之对指定IP进行端口扫描
    上一篇:PowerShell小技巧之获取Windows系统密码Hash
    下一篇:PowerShell小技巧之实现文件下载(类wget)
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    PowerShell小技巧之获取域名whois信息 PowerShell,小,技巧,之,获取,