Install
openclaw skills install fofa-query网络空间资产搜索引擎,支持 IP/域名/端口/协议/证书等多维度查询;当用户需要进行网络资产发现、安全研究、漏洞资产定位、证书分析或需要查询特定特征的互联网资产时使用
openclaw skills install fofa-query本 Skill 需要配置 FOFA API 凭证。请访问 https://fofa.info 登录账号,进入「个人中心」→「API 信息」页面,将邮箱和 API Key 用冒号组合(格式:email:key)。
配置示例:
user@example.com:abc123def456
将 FOFA API 凭证配置为环境变量 FOFA_API_KEY。
配置示例:
export FOFA_API_KEY="user@example.com:abc123def456"
{
"skills": {
"entries": {
"fofa-query": {
"enabled": true,
"apiKey": "FOFA_API_KEY"
}
}
}
}
在使用前,可以先检查用户信息和额度:
python scripts/fofa_query.py --user-info
使用 scripts/fofa_query.py 执行查询操作:
python scripts/fofa_query.py -q '查询语句'
常用参数:
-q, --query: 查询语句(必需)-f, --fields: 返回字段(默认:host,ip,port)--page: 页码(默认:1)--size: 每页结果数(默认:100,最大:10000)--format: 输出格式(text/json/table,默认:text)智能体应根据用户需求,参考 references/query_syntax.md 构建准确的查询语句。
语法要点:
field="value"&&(与)或 ||(或)连接(condition1 && condition2) || condition3field*="value*"# 查询指定 IP
python scripts/fofa_query.py -q 'ip="1.1.1.1"'
# 查询指定域名
python scripts/fofa_query.py -q 'domain="qq.com"'
# 查询指定端口
python scripts/fofa_query.py -q 'port="8080"'
# 查询同时开放 80 和 443 端口的主机
python scripts/fofa_query.py -q '(port="80" && port="443")'
# 查询指定国家的 nginx 服务器
python scripts/fofa_query.py -q 'server="nginx" && country="CN"'
# 查询使用 Let's Encrypt 证书的网站
python scripts/fofa_query.py -q 'cert.issuer="Let\'s Encrypt" && cert.is_valid=true'
# 获取统计信息
python scripts/fofa_query.py -q 'domain="baidu.com"' --stats
# 查询特定时间范围
python scripts/fofa_query.py -q 'after="2024-01-01" && before="2024-12-31" && domain="example.com"'
# 通过指纹查询
python scripts/fofa_query.py -q 'icon_hash="-247388890"'
智能体应对查询结果进行分析和解读:
port="80" 等常见特征会导致结果过多&& 连接多个条件缩小结果范围用户请求:"帮我查找 Google 的资产"
执行流程:
org="Google LLC"python scripts/fofa_query.py -q 'org="Google LLC"' --size 50
用户请求:"查找使用 Apache 2.4.49 的服务器"
执行流程:
server="Apache/2.4.49"python scripts/fofa_query.py -q 'server="Apache/2.4.49"' -f "host,ip,port,server,country"
用户请求:"查找使用 Let's Encrypt 证书的中文网站"
执行流程:
cert.issuer="Let's Encrypt" && title="中文关键词"python scripts/fofa_query.py -q 'cert.issuer="Let\'s Encrypt" && title*="管理"'
使用 --stats 参数获取聚合统计:
python scripts/fofa_query.py -q 'domain="example.com"' --stats
使用 --format json 获取结构化数据:
python scripts/fofa_query.py -q 'ip="1.1.1.1"' --format json
通过 -f 参数指定返回字段:
python scripts/fofa_query.py -q 'domain="qq.com"' -f "host,ip,port,title,server,country"
可能原因:
解决方案:
建议:
排查步骤: