Update README

This commit is contained in:
tidesec 2019-02-24 00:17:12 +08:00
parent c8d03f35b9
commit 7a0b876aa4

101
README.md
View File

@ -6,6 +6,7 @@ Tide(潮汐)是由新潮信息TideSec团队推出的一款网络空间资产搜
Tide(潮汐)目前实现了网络空间资产探测、指纹检索、漏洞检测、漏洞全生命周期管理、poc定向检测、暗链检测、挂马监测、敏感字检测、DNS监测、网站可用性监测、漏洞库管理、安全预警等~
在这里和大家分享一下Tide在空间测绘方面实现的一些方法和技巧虽然和zoomeye、fofa没什么可比性但平台整体成本比较低比较适用于小团队开发运作
```
tips1:两三个人利用两周时间完成了大体的框架但后续各种优化完善断断续续搞了小半年时间目前来说还是和zoomeye差距灰常大。
@ -20,10 +21,19 @@ tips4:感谢Xxlm、Yune、紫瀚等团队成员的长期付出www.tidesec.net
**Demo地址`http://demo.tidesec.net`**
(经同行提示,该平台可能涉及互联网基础信息搜集可能不合规,所以暂时下线,见谅。)
****
# 目录
* [Change_Log](#Change_Log)
* [建设背景](#建设背景)
* [主要功能及实现方法](#主要功能及实现方法)
* [资产发现](#资产发现)
* [指纹识别](#指纹识别)
* [扫描管理](#扫描管理)
* [POC检测](#POC检测)
* [安全监测](#安全监测)
* [Function](#Function)
* [前台展示](#前台展示)
* 前台主界面
@ -60,7 +70,96 @@ tips4:感谢Xxlm、Yune、紫瀚等团队成员的长期付出www.tidesec.net
- [2018-05-02] 爬虫功能、安全监测、poc检测基本实现测试了很多的工具和脚本
- [2018-03-18] 基本实现了网络资产的自动化探测、端口开放检测、指纹识别等
- [2018-02-13] 初步定好了几个大的功能框架包括资产探测、poc检测、安全监测等
# 建设背景
随着配合网安的一些工作越来越多,有时候经常需要对一定范围内的主机或应用系统进行摸排。
比如我们坐标山东而山东省持有的IP地址大约为1800万数据来自IANA、纯真IP和差错网如果每次都需要扫一些端口和服务那需要耗费比较多的时间和精力。如果想快速获取指定地区的资产信息就只能从zoomeye、shodan、fofa等类似的平台获取但这些平台一般查询都有一定限制比如限制条数比如工控端口没法查看ip等等而且在某一特定地区的精准度可能稍微差一些所以萌生了自己仿钟馗之眼做个资产探测平台的想法。
开始只是想仿个zoomeye能探测一定范围内的空间资产但后来断断续续加入了很多功能模块就有了现在的Tide。目前已经基本能满足某一地区的资产的搜集探测在一些网安的配合工作中也能快速出一些数据其他一些功能模块也在逐渐完善待大体完善后考虑开源。
由于平台是两三个人在项目之余慢慢堆积出来的没有懂前端的所以前台展示借鉴了zoomeye和fofa的页面不知道有没有侵权大佬不要打我们。。
# 主要功能及实现方法
之前画的一个框架图,大部分实现了,有些还在努力。
![pic](https://raw.githubusercontent.com/TideSec/Tide/master/images/架构.png)
## 资产发现
目前主要是对山东省内资产进行发现探测也包含了部分其他省份和云上资产内网生产数据库中数据量为3000Wweb类资产大约160W。
1、由于人力、物力、财力都比较有限所以只部署了十来台探测节点还是512M内存进行持续性探测探测可分为模糊探测和精准探测两种模式模糊探测时每天大约探测主机500W精准探测时大约为20W主机、3万web应用。
模糊探测主要是使用masscan和zmap结合去发现开放的主机和端口精确探测使用了自己写的一些脚本去发现逐个测试端口可用性再用nmap获取指纹信息我们也在对一些工控协议、物联协议写一些探测脚本并加入到指纹识别中。后续会慢慢写一些关于端口探测和指纹识别的一点心得。
在平台前期只是使用了nmap进行扫描并获取指纹后来发现效率太低太低让人无法忍受而且nmap在获取指纹时经常出现内存错误导致无法扫描的情况所以后来使用了masscan和zmap等结合的方式目前也在尝试使用zgrab等一些新的方式来提高效率和准确度。
2、十来台探测节点中一半是用来探测新的任务新的任务可以由前台提交在前台没有任务时会对随机ip进行探测另外一半节点是对旧的资产进行回归探测这样基本能保证系统中的数据都能比较新。比较遗憾的是目前还只是保存最新的数据对历史数据没有进行保存。
扫描节点的任务调度费了一些劲目前是根据各扫描节点领取的任务和花费的时间进行评分这样一些优先级比较高的任务就可以调度评分高的扫描节点来执行任务。不过目前还都是在同一个局域网环境中所以评分差别不是很大。经过测试512内存和1G内存的评分的确有些差距。
3、对大范围的ip地址的探测精准度和速度还有待提升根据目前的探测效率大体算了下全球互联网精准探测估计得两年大规模探测方面和zoomeye或fofa还差的太远。。。留下了没有技术的泪水。。。
## 指纹识别
1、对操作系统版本、开放端口、提供的服务、服务版本进行识别进行识别。
这部分主要是靠nmap来实现目前也在研究指纹识别的一些原理性东西打算以后能自己实现个探测引擎。nmap的最大问题是效率比较低有时候配置一些参数(如--min-hostgroup和--min-parallelism)可以提高速度,但误报率又会升高。所以在扫描时,节点会根据网络情况自动选择一些参数。
比较常用的参数:
```
nmap -sS -sV -T4 -O --script=banner --open --min-hostgroup 1024 --min-parallelism 1024 --host-timeout 30m -p 80
```
对扫描的结果进行提取分析,并导入数据库。
没有用pynmap库之前用了段时间发现经常报错好像和nmap的内存优化有一定关系。所以后来直接调用nmap生成.xml再解析。
2、对服务端语言、Web开发框架、Web应用CMS、前端库、第三方组件等进行识别。
web应用的指纹稍微复杂自己实现了几个小的工具来探测http头、waf、cms等借鉴了whatweb、wafw00f的一些思路。
3、通过接口查询、字典枚举等方式获取该域名下的所有子域名根据需要映射出目标网络的整体结构。
对每个web目前都会进行子域名枚举这样能进可能多的发现一些web应用子域名枚举借鉴了lijiejie和猪猪侠的子域名枚举思路还搭配使用了谷歌、百度子域名检索等方式并对泛解析也进行了预判。
## 扫描管理
1、漏洞扫描主要整合了wvs、w3af和自研的一些小平台把漏洞进行汇总整理并导出详细报告。
因为wvs的结果是英文的如果需要提供报告给客户的话友好度不高所以对wvs的扫描结果、加固建议、漏洞描述等进行了汉化。
对wvs的汉化主要是爬取了wvs官方的漏洞库对较为常见的漏洞进行了人工翻译然后使用谷歌翻译对其他漏洞进行了翻译人工进行了核对最终大约包含670个漏洞。
汉化后的数据库可从这个项目中获取,`https://github.com/TideSec/WDScanner`在数据库文件的vul_cn表中。
![pic](https://raw.githubusercontent.com/TideSec/Tide/master/images/vul_cn.jpg)
2、可根据配置地址对应用系统进行自动扫描还可设置定时扫描、扫描周期、扫描范围等相关功能以满足用户多元化需求。
3、可记录漏洞的概念以及漏洞的整个生命周期包括漏洞的产生、发现、公开、管理和消亡并详细介绍漏洞在生命周期中每个阶段的成因、形式、发现方法和具体的应对措施。
## POC检测
1、POC检测使用了成熟的POC框架POCSUITE修改了一些借口和Tide能完美对接改写了很多插件让检测更自动化。
POC检测应该是最有用的功能了可以对某一地区某端口进行检索然后将结果导入到poc检测任务中进行快速、批量的检测。
2、对常见插件漏洞、中间件漏洞等通用漏洞进行检测如weblogic反序列化、Struts2等漏洞进行验证。在新漏洞爆发时用户可利用该功能进行针对性检测。
## 安全监测
1、在敏感信息对重点客户进行持续性的监测采用全文检索、应用目录枚举、图片文件检查等手段对网站进行敏感信息检测并对发现的敏感信息进行导出从而协助用户对网站进行有效监管。
2、可7*24小时对网站进行监控模拟访客请求访问实时获取响应状态、响应时间、响应结果及时发现网站异常情况。
3、针对网站出现增加、删除、修改、挂马等安全事件时进行实时快照并留存用户可快速找到安全事件记录以便进行溯源追查。
# Function