时间:2023-02-09 00:24:01 | 来源:建站知识
时间:2023-02-09 00:24:01 来源:建站知识
声明:本文初衷为分享网络安全知识,请勿利用技术做出任何危害网络安全的行为,由于传播、利用此文所提供的信息而造成的任何直接或者间接的后果及损失,均由使用者本人负责
扩大资产范围,可以增加漏洞发现的概率子域名收集通常分为两种方式,分别为被动收集和主动收集。
众所周知,一般情况下主站的安全性可能相对较高,而一些不常用的子站或者上线不久的站点,可能安全方面的考虑还没有很周全,可能成为目标系统的脆弱点
通常情况下,同一组织采用相同应用搭建多个服务的可能性很大,以及补丁的情况也可能大致相同,因此,存在相同漏洞的概率非常大
信息泄露主动收集是指,通过与目标系统进行交互,对子域名进行收集。因为需要和目标系统进行交互,很可能出现高频访问等情况,有触犯安全产品告警的风险。
搜索引擎
网络空间测绘引擎
证书透明
第三方DNS服务
AS 号码查询
SAN 收集
使用公共数据集
字典枚举
置换扫描
域传送漏洞
DNSSEC
DNS缓存
【→所有资源关注我,私信回复“资料”获取←】搜索引擎
1、网络安全学习路线
2、电子书籍(白帽子)
3、安全大厂内部视频
4、100份src文档
5、常见安全面试题
6、ctf大赛经典题目解析
7、全套工具包
8、应急响应笔记
site:*.baidu.com
一般用作工具搜集的补充,也可以编写脚本进行批量操作常见的空间测绘引擎:直接在搜索框使用语法进行搜素,基础语法:
Shodan
Zoomeye
Fofa
domain=Your_domain
也可以利用API进行搜索echo 'domain="baidu.com"' | base64 - | xargs -I{} curl "https://fofa.info/api/v1/search/all?email=${Your_Mail}&key=${Your_Key}&page=1&qbase64={}"
再编写个脚本,对返回的数据进行简单的处理,即可获得一个子域名列表。import requestsfrom base64 import b64encodeimport json# 配置信息domain = 'domain="baidu.com"'domain = str(b64encode(domain.encode("utf-8")), "utf-8")email = "Your_email"key = "Your_key"# endurl = "https://fofa.info/api/v1/search/all?email={email}&key={key}&qbase64={domain}".format(email=email, key=key, domain=domain) + "&page={page}"page = 1subdomain = list()while True: url = url.format(page=str(page)) req = requests.get(url=url).text result = json.loads(req)['results'] if result: tmp = [i[0] for i in result] subdomain += tmp else: break page += 1print(set(subdomain)) # 去重
注:这里的代码仅仅是展现处理的逻辑,暂未考虑优化处理,第三方DNS服务
VirusTotal会运行DNS复制功能,通过存储用户访问URL时执行的DNS解析来构建数据库。
其他在线DNS工具汇总:证书透明
https://decoder.link/
https://searchdns.netcraft.com/
https://dnsdumpster.com/
https://pentest-tools.com/information-gathering/find-subdomains-of-domain
https://www.pkey.in/tools-i/search-subdomains
https://hackertarget.com/find-dns-host-records/
https://findsubdomains.com/
https://spyse.com/
常用证书透明查询网站使用也是比较简单,直接搜索主域名即可。因为这种方法的原理是根据日志信息收集,只增不减,所以可能会出现一些失效的子域名。
censys:https://censys.io/certificates
crtsh:https://crt.sh/
spyse:https://spyse.com/search/certificate
certspotter:https://sslmate.com/certspotter/api/
entrust:https://www.entrust.com/ct-search/
facebook:https://developers.facebook.com/tools/ct
google:https://developers.facebook.com/tools/ct
AS 号码帮助识别属于组织的网络块,而该网络快又可能具有有效域查找ASN
nmap --script targets-asn --script-args targets-asn.asn=Your_asn > netblocks.txt
像fofa这类的网络空间测绘引擎也支持ASN查找sed -ne 's/^/( */)Subject://1/p;/X509v3 Subject Alternative Name/{ N;s/^.*/n//;:a;s/^/( */)/(.*/), //1/2/n/1/;ta;p;q; }' < <( openssl x509 -noout -text -in <( openssl s_client -ign_eof 2>/dev/null <<<$'HEAD / HTTP/1.0/r/n/r' / -connect baidu.com:443 ) )
公开数据集https://scans.io/study/sonar.rdns_v2通常这些数据集都是比较大,可以使用命令进行快速查找
https://opendata.rapid7.com/
wget https://scans.io/data/rapid7/sonar.fdns_v2/20170417-fdns.json.gzcat 20170417-fdns.json.gz | pigz -dc | grep ".Your_Target.org" | jq
部分工具可能长时间没更新,字典可能比较老旧,可以根据需求修改成自己的字典置换扫描
# 1.nslookup命令进入交互式shell$ nslookup# 2.server命令 参数设定查询将要使用的DNS服务器$ server xxx.com# 3.如果漏洞存在的话,可以使用ls命令列出所有域名$ ls# 4.退出$ exit
digdig @Target_DNS_Server_IP axfr 查询的域名
dnswalkdnswalk your_domain.
nmapnmap --script dns-zone-transfer --script-args dns-zone-transfer.domain=Your_domain -p 53 -Pn dns.xxx.yyy.com
DNSSECapt-get install ldnsutils
./dnsrecon.py -t snoop -n Sever -D <Dict>
OneForAll是一款比较综合的子域名扫描工具,拥有多个模块和接口扫描,收集子域信息很全,包括子域、子域IP、子域常用端口、子域Title、子域Banner、子域状态等。
git clone https://gitee.com/shmilylty/OneForAll.gitdocker pull shmilylty/oneforalldocker run -it --rm -v ~/results:/OneForAll/results -v ~/OneForAll/config:/OneForAll/config shmilylty/oneforall --target baidu.com run
扫描结果路径:~/resultsksubdomain
置文件路径:~/OneForAll/config
目标域名:http://baidu.com
ksubdomain是一款基于无状态子域名爆破工具,支持在Windows/Linux/Mac上使用,它会很快的进行DNS爆破,在Mac和Windows上理论最大发包速度在30w/s,linux上为160w/s的速度。
TIPS:在linux下,还需要安装libpcap-dev,在Windows下需要安装WinPcap,mac下可以直接使用。
# 使用内置字典爆破ksubdomain -d baidu.com# 使用字典爆破域名ksubdomain -d baidu.com -f subdomains.dict# 字典里都是域名,可使用验证模式ksubdomain -f dns.txt -verify# 爆破三级域名ksubdomain -d baidu.com -l 2
Sublist3rSublist3r使用许多搜索引擎(如Google,Yahoo,Bing,Baidu和Ask)进行子域名探测。
Sublist3r还使用Netcraft,Virustotal,ThreatCrowd,DNSdumpster和ReverseDNS进行子域名探测。
python sublist3r.py -b -d baidu.com
-d -domain要枚举子域的域名altdns
-b -bruteforce启用subbrute bruteforce模块
-p -ports根据特定的tcp端口扫描找到的子域
-v --verbose启用详细模式并实时显示结果
-t -threads用于subbrute bruteforce的线程数
-e - 引擎指定逗号分隔的搜索引擎列表
-o -output将结果保存到文本文件
-h -help显示帮助信息并退出
Altdns是一款运用置换扫描技术的子域发现工具,它可以帮助我们查找与某些排列或替换匹配的子域。AltDNS接受可能存在于域下的子域中的单词(例如测试,开发,分期),以及获取你知道的子域列表。
使用者只需提供两个输入列表,altdns就可以为我们生成输出大量可能存在的潜在子域并保存。这些保存好的子域列表,用作DNS爆破字典是个不错的选择。
python altdns.py -i subdomains.txt -o data_output -w words.txt -r -s results_output.txt
subdomains.txt 文件包含了目标的已知子域当然,优秀的工具还有许多,这里仅仅是举了几个我个人觉得比较常用工具的使用方法。只有合理地使用,才能把工具的作用发挥到最大。常见的工具还有:
data_output文件将包含大量的更改和置换的子域列表
words.txt是需要置换子域的单词列表(即admin,staging,dev,qa)- 单词以行分隔
results_output.txt 将包含被发现有效的且具有DNS记录的排列后子域的最终列表。
-r命令解析每个生成的已排列的子域
-s命令用于指定altdns在哪保存已解析的排列子域结果。
-t命令用于指定解析器同时使用的线程数
关键词:收集,姿势,总结,系列,安全,信息,网络