有没有人知道API /脚本给我一个IP地址网络的CIDR?不是IP范围到CIDR!
背景:欺诈者在我的网站上注册并使用代理或网络托管服务商隐藏他的IP地址或伪造他的IP位置。现在,阻止他的IP地址是没有意义的。我想锁定主机的整个网络进行注册。所以我需要让ip whois获得网络的CIDR。我想自动化它。
答案 0 :(得分:8)
IP地址由LIR(本地Internet注册表)发布给最终用户。 LIR需要在其相应的RIR(地区互联网注册管理机构)数据库中注册任何指定地址空间的各种详细信息。有5个RIR(ARIN,RIPE NCC,APNIC,LACNIC和AfriNIC)负责世界不同地区。据我所知,他们都提供RESTful API,您可以使用它来获取所需的信息。
例如,如果IP来自欧洲,您可以使用RIPE API搜索inetnum或路由与某个IP地址相关的对象:
http://rest.db.ripe.net/search?query-string=194.79.41.40
您将在whois-resource
内获得多个对象,而您最感兴趣的对象是route
对象:
<object type="route">
<link xlink:type="locator" xlink:href="http://rest.db.ripe.net/ripe/route/194.79.40.0/22AS35796"/>
<source id="ripe"/>
<primary-key>
<attribute name="route" value="194.79.40.0/22"/>
<attribute name="origin" value="AS35796"/>
</primary-key>
<attributes>
<attribute name="route" value="194.79.40.0/22"/>
<attribute name="descr" value="NBS"/>
<attribute name="origin" value="AS35796" referenced-type="aut-num">
<link xlink:type="locator" xlink:href="http://rest.db.ripe.net/ripe/aut-num/AS35796"/>
</attribute>
<attribute name="mnt-by" value="NBS-MNT" referenced-type="mntner">
<link xlink:type="locator" xlink:href="http://rest.db.ripe.net/ripe/mntner/NBS-MNT"/>
</attribute><attribute name="source" value="RIPE" comment="Filtered"/>
</attributes>
</object>
请记住,此路由对象可以是比用户实际所属的更大的汇总范围,但这是您可以获得的最佳范围。
检查以下链接以了解其他RIR:
修改强> 我应该在我的原始答案中提到这一点,但我被API部分分心了。在所有这些背后实际上是一个非常简单的whois协议,特别是如果您正在处理解析JSON或XML需要一些工作的编程语言。
Whois协议使用TCP端口43,在连接到服务器之后,您只需要发送搜索密钥(在您的情况下是IP地址)。您将获得响应,服务器将终止连接。就是这样。您可以尝试telnet whois.ripe.net 43
并在打开连接后发送194.79.41.40
或RIPE NCC发布的其他IP。
whois的一个问题是没有中央数据库可以查询并始终获得结果,而是需要查询发出特定IP的RIR。但即使你想念&#39;正确的RIR和查询(例如)whois.iana.org为RIPE NCC发布的地址,您将获得与发出IP的权利whois服务器和组织(RIR)的响应。因此,您可以检查用户的地理位置统计信息,并优先考虑最有可能获得结果的whois服务器,或使用响应选择要查询的第二台服务器。
另一个问题是响应未标准化,因此您必须为5台whois服务器中的每一台制作响应解析器。