Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/orleven/Hamster
Hamster是基于mitmproxy开发的异步被动扫描框架,基于http代理进行被动扫描,主要功能为重写数据包、签名、漏洞扫描、敏感参数收集等功能(开发中)。
https://github.com/orleven/Hamster
passive-scanner poc script webscanner
Last synced: about 2 months ago
JSON representation
Hamster是基于mitmproxy开发的异步被动扫描框架,基于http代理进行被动扫描,主要功能为重写数据包、签名、漏洞扫描、敏感参数收集等功能(开发中)。
- Host: GitHub
- URL: https://github.com/orleven/Hamster
- Owner: orleven
- Created: 2017-12-24T14:44:25.000Z (about 7 years ago)
- Default Branch: master
- Last Pushed: 2024-10-31T08:10:01.000Z (3 months ago)
- Last Synced: 2024-10-31T09:18:47.959Z (3 months ago)
- Topics: passive-scanner, poc, script, webscanner
- Language: Python
- Homepage:
- Size: 2.31 MB
- Stars: 69
- Watchers: 4
- Forks: 13
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Support: support.py
Awesome Lists containing this project
- awesome-hacking-lists - orleven/Hamster - Hamster是基于mitmproxy开发的异步被动扫描框架,基于http代理进行被动扫描,主要功能为重写数据包、签名、漏洞扫描、敏感参数收集等功能(开发中)。 (Python)
README
# 概述
Hamster是基于mitmproxy开发的异步被动扫描框架,基于http代理进行被动扫描,主要功能为重写数据包、签名、漏洞扫描、敏感参数收集等功能(开发中)。
[![Python 3.9](https://img.shields.io/badge/python-3.9-yellow.svg)](https://www.python.org/)
[![Mysql 8.0](https://img.shields.io/badge/mysql-8.0-yellow.svg)](https://www.mysql.com/)
[![RabbitMQ 3](https://img.shields.io/badge/rabbitmq->=3-blue.svg)](https://www.rabbitmq.com/)
[![Redis 3](https://img.shields.io/badge/redis->=3-blue.svg)](https://redis.io/)# 模块
1. 漏洞扫描:`brower/burpsuite → server → rabbitmq ->agent → support → target `
2. 渗透测试辅助:`brower/burpsuite → server → target`## server:
1. 被动扫描代理端口
2. 管理控制台
3. 推送流量到agent进行扫描
4. 手工测试时进行签名、waf绕过。## agent
1. 漏扫
2. 扫描的poc发送到supprt进行签名、waf绕过等## supprt
1. 代理端口。
2. 给agent进行签名、waf绕过等。
3. 手工测试时进行签名、waf绕过。## manager
1. 管理控制台# 安装
## 代码部署
```
# PIP安装依赖
python3.9 -m venv venv
source venv/bin/activate
pip install -r requirements.txt# 如没有conf文件夹,则需要先生成配置文件,先运行一次init.py,生成相关配置文件(默认是dev环境)
python init.py# 通过修改 conf/online/*.conf 配置mysql,redis,rabbitmq,dnslog等, 可查看配置说明
vim conf/online/*.conf# 再一次运行,初始化数据库。
python init.py# 运行server
nohup python server.py &# 运行agent
nohup python agent.py &# 运行support
nohup python support.py &# 运行manager(可选)
nohup python manager.py &
```## Docker部署
```
# 通过dockerfile文件部署 mysql,redis,rabbitmq
cd docker# 通过修改 conf/online/*.conf 配置dnslog等, 可查看配置说明
vim conf/online/*.conf# 开始部署docker
docker-compose up -d
```# 使用
## 设置代理
设置浏览器HTTP代理或者设置burpsuite二级代理`upstream proxy servers`, 代理认证请配置 `conf/online/hamster_basic.conf`.
![burpsuite_proxy](show/burpsuite_proxy.png)
* host: localhost
* port: 8000
* authtype: basic
* username: Hamster
* password: Hamster@123## 扫描
然后浏览器访问目标网站就可以进行漏洞扫描了。
## 查看扫描结果
可以随时通过访问控制台查看扫描结果(控制台有如下两种访问方式)
1. 通过server代理访问,http://admin.hamster.com/hamster/online/login
2. 通过manager直接访问,http://127.0.0.1:8002/hamster/online/login访问凭据:
* username: admin
* password: Hamster@123![web](show/web.png)
# 配置说明
因为有不少漏洞需要配合DNSLOG,因此需要配置dnslog,本项目默认使用`oast.pro, oast.live, oast.site, oast.online, oast.fun, oast.me`项目接口,同时内置[DNSLog](https://github.com/orleven/Celestion)api接口,当然也可以使用其他dnslog,不过需要编写接口,相关代码在`/lib/core/api.py`中的`get_dnslog_recode`函数。
1. 通过修改 `conf/online/hamster_basic.conf` (第一次运行后生成) 配置mysql,redis,rabbitmq,dnslog,具体请看注释。
# 插件编写
插件目录为`addon`,具体功能如下(addon本后续不再更新):
1. `addon/agent` agnet用, 主要存放扫描poc。
2. `addon/common` server、support共用,可用于给数据包waf、sign等。
3. `addon/server` server用,一般涉及数据包加解密时和supprt联用。
4. `addon/support` support用,一般涉及数据包加解密时和server联用。同目录下addon按照字母顺序加载,如果脚本之间存在运行先后逻辑,请合理安排脚本文件名。
PS: 参考插件模版目录`test_addon`即可。
# 关于缓存日志查询
为了覆盖延迟型的SSRF、Log4j2等漏洞,对于此类数据包进行了缓存,缓存日志保存天数,默认2天,数据库缓存默认1天。
1. 如果dnslog告警了,请等待2分钟后,在漏洞中查看。
2. 如果短时间内触发多个dnslog,且漏洞仅更新了1个的话,这是因为这几个dnslog的触发原因是一样的,漏洞已做了去重处理,忽略就行。
3. 如果dnslog告警,且漏洞没有更新,表示这个漏洞是延迟触发的,且超过了数据库缓存天数,可以尝试在logs目录中查找,如果还是没找到,那就是说明延迟太久了,缓存已经没了。```
find log/ -name "*" -print0 | xargs -0 grep -i -n "{dnslog}" 2>/dev/null
```# mysql binlog文件过大问题
编辑 `my.cnf` 并在`[mysqld]`下添加`skip-log-bin`关闭binlog,并重启mysql即可。
```
set global binlog_expire_logs_seconds=10;
set persist binlog_expire_logs_seconds=10;
```# xray poc 兼容
`poc/xray/pocs` 简单兼容了xray poc,目前这个模块写的比较糙,不建议放入全部poc。