GitHound是一款什么工具
这篇文章主要介绍GitHound是一款什么工具,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!
GitHound
GitHound可以利用模式匹配、提交历史楼所和一个独特的结果评分系统来精确定位GitHub上的公开API密钥,从本质上来说,GitHound就是一款基于批量爬取、模式匹配和补丁攻击的敏感数据搜索工具。
值得一提的是,目前为止在GitHound的帮助下,我已经成功拿到了超过7500美元的漏洞奖金了。
功能介绍
1、GitHub/Gist代码搜索。这个功能将允许GitHound搜索GitHub中用户上传的所有代码库,并准确定位到敏感信息所在的位置。
2、通用APK密钥检测,该功能使用了模式匹配、上下文检索和香农熵。
3、提交历史搜索,该功能可以找到没有正确删除的敏感信息。
4、评分系统,可以返回更加准确的结果,过滤常见的误报,并优化密集型代码库挖掘结果。
5、Base64检测和解码。
6、可将GitHound构建整合进我们自己的工作流中。
工具下载
广大研究人员可以使用下列命令将GitHound项目源码克隆至本地:
git clone https://github.com/tillson/git-hound.git
工具安装
使用我们自己的GitHub用户名和密码创建一个./config.yml或~/.githound/config.yml文件,目前还不支持使用开启了双因素身份验证的账号。
样本config.example.yml文件格式如下:
# Requiredgithub_username: tillsongithub_password: a8ueifjq4jkasdfoiulk
然后运行下列命令:
echo "tillsongalloway.com" | git-hound
工具使用
echo "tillsongalloway.com" | git-hound or git-hound --subdomain-file subdomains.txt
使用样例
搜索公开的用户API密钥
通过了解特定服务的API密钥的模式,我们将能够使用GitHound来搜索GitHub中的这些公开用户API密钥。然后,我们可以将自定义的密钥正则表达式整合进我们的脚本中,然后针对目标服务API密钥来标识有风险的账户。
echo "api.halcorp.biz" | githound --dig --many-results --regex-file halcorp-api-regexes.txt --results-only | python halapitester.py
漏洞奖励:搜索泄露的员工API令牌
对于我个人来说,GitHound的主要用途就是针对漏洞奖励计划来搜索敏感信息。对于某些重要目标,我们可以使用--many-results和--languages来搜索>100页得结果。
echo "uberinternal.com" | githound --dig --many-results --languages common-languages.txt --threads 100
工具选项
--subdomain-file - 包含子域名的文件;
--dig-files - 克隆并搜索目标代码库中的文件以获取结果;
--dig-commits - 克隆并搜索目标代码库中的提交历史以获取结果;
--many-results - 使用结果排序和过滤搜索超过100页的结果;
--results-only - 仅将正则匹配得结果打印到stdout,用于将自定义正则表达式匹配项管道化到另一个脚本中;
--no-repos - 指定不需要搜索的代码库;
--no-gists - 指定不需要搜索的Gist;
--threads -指定提交挖掘程序要使用的最大线程数;
--regex-file - 提供自定义正则表达式文件;
--language-file - 提供带有要搜索的语言的自定义文件;
--config-file - 自定义配置文件(默认为config.yml);
--pages - 要搜索的最大页面数(默认值为100);
--no-scoring - 不使用评分来过滤假阳性;
--no-api-keys - 不执行通用api密钥搜索。GitHound使用常见的API密钥模式、上下文检索和香浓熵过滤器来查找潜在的公开API密钥;
--no-files - 不标记感兴趣的文件扩展名;
--only-filtered - 仅搜索筛选查询(语言);
--debug - 打印详细的调试消息;
以上是"GitHound是一款什么工具"这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注行业资讯频道!