Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

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代理进行被动扫描,主要功能为重写数据包、签名、漏洞扫描、敏感参数收集等功能(开发中)。

Awesome Lists containing this project

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。