python子域名收集工具

在网络安全领域中,发现和管理攻击面绝对是一项必须的任务,而对域名的寻找和分析是发现攻击面的重要步骤。今天我们将与您分享关于域名发现的四种方法,并附带Python示例代码来帮助您更好的理解和掌握这些方法。

1. 主域名链式证书提取域名信息(Chain of Trust from Root Domain)

import ssl
import OpenSSL

def get_cert_chain(domain):
    cert = ssl.get_server_certificate((domain, 443))
    x509 = OpenSSL.crypto.load_certificate(OpenSSL.crypto.FILETYPE_PEM, cert)
    return [value for value in x509.get_subject().get_components()]

print(get_cert_chain('example.com'))

2. 证书透明度日志(Certificate Transparency Logs)

import requests

def query_crt_sh(domain):
    url = f"https://crt.sh/?q={domain}&output=json"
    response = requests.get(url)
    try:
        return [result['name_value'] for result in response.json()]
    except:
        return []

print(query_crt_sh('example.com'))

3. 站长工具(Webmaster Tools)

import requests
from bs4 import BeautifulSoup

def query_webmaster_tools(domain):
    base_url = f"https://whois.chinaz.com/{domain}"
    page = requests.get(base_url)
    bs_obj = BeautifulSoup(page.text, "html.parser")
    return [pre.text for pre in bs_obj.find_all('pre')]

print(query_webmaster_tools('example.com'))

4. 子域名爆破(Subdomain Enumeration)

对实际环境中常见的子域名前缀进行枚举。

import socket

def enum_subdomains(domain):
    common_subdomains = ['www', 'ftp', 'mail', 'webmail', 'admin']
    for subdomain in common_subdomains:
        full_domain = f"{subdomain}.{domain}"
        try:
            # if the subdomain resolves, it exists
            socket.gethostbyname(full_domain)
            print(f"Discovered subdomain: {full_domain}")
        except socket.gaierror:
            pass

enum_subdomains('example.com')

根据目标和环境选择适合的工具进行深入挖掘总能帮助我们更好的发现攻击面。希望以上的信息会对你有所帮助。

写在最后

云图极速版支持包含上述几种在内的 20 余种域名发现方式,通过智能编排的方式动态调用以实现域名发现覆盖度的最大化。除此之外,云图极速版还支持 IP 发现、端口、服务、网站、组件、漏洞、安全风险等多种企业资产信息的全自动发现与监控。实现攻击面发现与攻击面管理的自动化。

相关推荐

  1. python域名收集工具

    2024-02-23 04:12:02       31 阅读
  2. python域名收集工具

    2024-02-23 04:12:02       30 阅读
  3. python域名收集工具

    2024-02-23 04:12:02       27 阅读
  4. python域名收集工具

    2024-02-23 04:12:02       29 阅读
  5. 收集域名信息

    2024-02-23 04:12:02       35 阅读

最近更新

  1. 【AI应用探讨】—主成分分析(PCA)应用场景

    2024-02-23 04:12:02       0 阅读
  2. 基数排序算法Python实现

    2024-02-23 04:12:02       0 阅读
  3. qt todoapp

    2024-02-23 04:12:02       0 阅读
  4. 如何减少开发过程中的bug-数据库篇

    2024-02-23 04:12:02       0 阅读
  5. 驻场运维的前途在哪里,这里有金玉良言

    2024-02-23 04:12:02       1 阅读
  6. 认字之 刬

    2024-02-23 04:12:02       1 阅读
  7. lvs集群

    lvs集群

    2024-02-23 04:12:02      0 阅读
  8. AUTOSAR:汽车软件架构的未来

    2024-02-23 04:12:02       0 阅读
  9. 相机光学(二十九)——显色指数(Ra)

    2024-02-23 04:12:02       0 阅读

热门阅读

  1. 3.Swift导航栏的使用

    2024-02-23 04:12:02       31 阅读
  2. 【Swift】NSPopUpButton用法和示例

    2024-02-23 04:12:02       31 阅读
  3. JBOSS EPA 7.X 接入Oracle数据源

    2024-02-23 04:12:02       28 阅读
  4. Leetcode | 231. 2 的幂 C语言

    2024-02-23 04:12:02       36 阅读
  5. QT 如何让多语言翻译变得简单,提高效率?

    2024-02-23 04:12:02       27 阅读
  6. Springcloud OpenFeign 的实现(二)

    2024-02-23 04:12:02       32 阅读