Ecosyste.ms: Awesome

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

Awesome Lists | Featured Topics | Projects

https://github.com/ATpiu/asset-scan

asset-scan是一款适用甲方企业的外网资产周期性扫描监控系统
https://github.com/ATpiu/asset-scan

golang network-discovery nmap port-scanner security service-discovery vulnerability-detection

Last synced: 21 days ago
JSON representation

asset-scan是一款适用甲方企业的外网资产周期性扫描监控系统

Awesome Lists containing this project

README

        

# asset-scan
[![Golang](https://img.shields.io/badge/Golang-1.13-yellow.svg?style=flat-square)](https://www.golang.org/) [![elasticsearch](https://img.shields.io/badge/Elasticsearch-5.6.8-green.svg?style=flat-square)](https://www.elastic.co/downloads/elasticsearch) [![kibana](https://img.shields.io/badge/Kibana-5.6.8-blue?style=flat-square)](https://www.elastic.co/downloads/kibana)

## 简介

asset-scan用于甲方企业外网资产进行周期性扫描监控,对资产新增的端口服务进行自动化未授权访问/弱口令爆破检测并进行实时告警,
便于企业对外网暴露的攻击面进行收敛

结合kibana,使用者可随时搜索企业外网资产暴露的端口、服务和版本等信息;制作各类统计图,进行开放端口统计、新增服务版本分析和资产扫描耗时统计等;
使用Dashboard进行内部汇报展示等

目前支持`ssh`、`redis`、`mysql`、`ftp`、`mongodb`、`postgresql`和`mssql`七种服务的弱口令爆破,另外支持`mongod`、`redis`和
`memcached`的未授权访问测试

**请使用者遵守《中华人民共和国网络安全法》,勿用于非授权的测试。**

## 功能特点

- 周期性扫描监控
- 自动化未授权访问/弱口令爆破
- 支持扫描速度、白名单、配置热更新和告警控制
- 搜索、自定义统计图、多维度分析、结果导出EXCEL

## 图例展示

配合Kibana强大的分析统计功能,各位可自定义其它统计图和表盘

![](./doc/dashboard.png)
![](./doc/IP开放高危服务表.png)

## 配置文件说明

```
nmap:
path: #不指定则使用系统默认的nmap

masscan:
path: #不指定则使用系统默认的masscan
rate: 5000 #masscan扫描速度,不建议设很大

es:
address: 127.0.0.1:9200 #elasticsearch地址

scan:
ipFile: ip.txt #包含扫描的ip范围文件,文件内容格式参照nmap -iL参数所支持的格式
ipexcludeFile: ipExclude.txt #包含需排除的ip范围文件,文件内容格式参照nmap --excludefile参数所支持的格式
port: 1-65535 #扫描端口范围
mas_num: 1 #同时可运行的最大masscan数
nmap_num: 20 #同时可运行的最大nmap数
userDict: user.txt #对服务进行弱口令爆破的用户名字典
passwordDict: password.txt #对服务进行弱口令爆破的密码字典
scan_interval: 30 #扫描间隔,单位:秒

observe:
switch: on #观察者模式开关:(1)开启:on (2)关闭:off

mail: #告警邮箱设置,若观察者模式始终开启,则可忽略邮箱配置
host: xxx.xxx.com
port: 123
username: [email protected]
password: xxx
from: [email protected]
to: ["[email protected]","[email protected]"]
```

## 运行指南

- Linux环境运行,需要Nmap、Masscan、Es和Kibana 5.6.x版本,安装指南详见:[安装指南](./doc/install.md)
- 所需组件安装完毕后,从[release](https://github.com/ATpiu/asset-scan/releases)中下载压缩包,对config.yaml进行配置,ip.txt中填入要扫描的IP段(格式参照nmap -iL参数所支持的格式),之后可直接输入`./asset-scan`运行
- 扫描初期,建议将config.yaml中的观察者模式开关设为`on`,避免造成告警轰炸(有新服务对外开放或暴力破解成功会发告警邮件)
- ipExclude.txt中为要排除扫描的IP段,user.txt和password.txt分别为用户名字典和密码字典

## kibana图表模板

- 有一些同学联系到作者希望能提供kibana图表模板,因此作者提供一个自己的kibana图表模板,方便大家查看效果及参考学习,详见:[图表模板](./doc/kibana.md)

## Es字段说明

目前Es中有5个type:
- result

包含每次资产基础探测扫描的数据:

- scanhistory

包含每次扫描的开始时间和结束时间

- addhistory

与最近一次扫描历史区间相比,新增的端口服务

- uphistory

与最近一次扫描历史区间相比,同一资产(具有相同IP、端口和协议)服务的更新情况

- bruteforce

包含对资产服务的未授权访问/暴力破解记录

## 讨论

与本项目有关的想法建议可联系作者,也欢迎一起讨论甲方安全建设/乙方安全服务/工控安全等

备注:github

![](./doc/wechat.jpg)