以下是一个简化的Python爬虫程序示例,用于从Fofa中批量获取CVE漏洞相关的信息。
import requests
import csv
# Fofa API 相关配置
FOFA_API_URL = "https://fofa.info/api/v1/search/all"
FOFA_EMAIL = "your_email@example.com"
FOFA_KEY = "your_fofa_api_key"
# CVE 列表,这里只列举了几个示例
cve_list = ["CVE-2017-11499", "CVE-2018-1000002", "CVE-2018-1000003"]
# 构建查询
queries = [f'title="{cve}"' for cve in cve_list]
# 结果文件
result_file = "cve_results.csv"
# 发送请求
def send_request(query):
payload = {
"email": FOFA_EMAIL,
"key": FOFA_KEY,
"query": query
}
response = requests.get(FOFA_API_URL, params=payload)
return response.json()
# 保存结果
def save_results(results, file_name):
with open(file_name, 'w', newline='', encoding='utf-8') as csvfile:
writer = csv.writer(csvfile)
writer.writerow(['CVE', 'Hostname', 'IP'])
for result in results:
hostname = result.get('hostname')
ip = result.get('ip')
for cve in cve_list:
writer.writerow([cve, hostname, ip])
# 主函数
def main():
results = []
for query in queries:
response = send_request(query)
results.extend(response.get('results'))
save_results(results, result_file)
if __name__ == "__main__":
main()
这个示例程序首先定义了Fofa API 的URL和认证信息,然后构建了一个CVE列表。通过循环构建查询,并发送请求到Fofa API获取数据,最后将结果保存到CSV文件中。
注意:实际使用时需要替换FOFA_EMAIL
和FOFA_KEY
为您的有效凭证,并确保您有足够的查询配额来执行这些查询。