Welcome to Vulfocus 🚀
Vulfocus 是一个漏洞集成平台,将漏洞环境 docker 镜像,放入即可使用,开箱即用。
Vulfocus 官网:https://fofapro.github.io/vulfocus/
在线 Vulfocus:
背景
漏洞靶场是目前每个安全人员以及想学习信息安全的人必备的东西,但目前商业化产品居多,还有一些类似 dvwa、 sqli-labs 这类的开源项目,但是漏洞环境比较固定,使用完一次后就失去其作用。搭建的成本过高,每次启动的流程会比较繁琐,甚至很多场景是不满足的,之前关于漏洞环境镜像使用多的是 vulhub,但是作为企业、高校等以及相关的培训,单纯的漏洞环境不一定能满足使用的需求,所以我们基于当下的一些靶场项目做出了小小的改进来符合我们的一些需求,比如增加 flag 的形式,来满足一些考核与验证的需求,可以对我们内部人员能力进行考核,于是 Vulfocus 就诞生了。
认识 Vulfocus
因为 Vulfocus 一个漏洞集成平台,所以可以无限向里添加漏洞环境没有限制,前提是你的内存足够大。因为漏洞环境是docker镜像的原因每次重新启动漏洞环境都会还原,不用出现你会对环境造成破坏下次无法启动的现象。
Vulfocus 的 docker 仓库 https://hub.docker.com/u/vulfocus
Vulfocus的特性
- 启动:一键漏洞环境启动,方便简单。
- 自带 Flag 功能:每次启动 flag 都会自动更新,明确漏洞是否利用成功。
- 带有计分功能也可适用于相关安全人员能力的考核。
- 兼容 Vulhub、Vulapps 中所有漏洞镜像。
- 支持可视化编排漏洞环境
使用
-
安装完成后,访问80端口
-
用设置好的管理员账户登录
-
首页为漏洞集成页面,刚开始是没有漏洞镜像的需要从 https://hub.docker.com/ 网站拉取镜像,或自己以tar包的形式上传。
漏洞镜像的拉取和上传(需管理员权限):
(1)、在镜像管理中,添加功能
(2)、分别填入漏洞名称、镜像、rank、描述
- 镜像又分为文件和文本
- 文本:是从 https://hub.docker.com/u/vulfocus 官网拉取镜像。内容为如:
vulfocus/webmin-cve_2019_15107
。- 文件:本地漏洞镜像打成tar包的形式上传。
-
下载完成后点击启动即可。
-
镜像启动后,会在环境里写入一个 flag (默认 flag 会写入 /tmp/ 下),读取到 flag 后填入 flag 窗口,镜像会自动关闭,如需重新启动,需强刷一下,然后再次点击启动即可。
-
可视化编排(管理员权限)
- 场景模式(普通用户权限)
- 计时模式
FAQ
普通用户无法查看漏洞题目?
1.以管理员身份登录系统,进入镜像管理界面,选择某一个镜像修改(如果这里镜像显示为空可以先添加镜像)
2.将镜像的分数设置为0
3.以普通用户身份登录进入vulfocus首页,这时可以看见自己刚才修改的镜像,启动镜像并且提交flag,通关后将显示所有镜像
镜像启动后立即访问地址失败?
- 根据镜像的大小,启动时间会有不同的延迟,一般在几秒以内。
提交完 flag 后会有卡住?
- 在提交完正确flag后,会镜像关闭的动作,所以会有几秒的延迟。
拉取镜像时一直卡在哪里
- 由于网络延迟或镜像太大的原因时间会长一点。
- 镜像名称填错,也会卡在哪里,建议强刷一下。
通过docker运行vulfocus提示服务器内部错误
1.通过docker logs命令查看容器日志信息
2.通过docker exec -it <container_id> /bin/sh命令进入容器(container_id为容器运行id)在容器内部执行tail -f celery.log查看后台日志信息
Centos 无权限操作Docker
环境一直处于启动中
- 查看celery.log的日志文件输出,检查是否抛出异常信息
- 检查服务器CPU和内存的使用情况,倘若内存和CPU不足也会导致镜像无法启动
如何将容器内部数据保存到主机上
docker create -p 80:80 -v /var/run/docker.sock:/var/run/docker.sock -v /xxx/db.sqlite3:/vulfocus-api/db.sqlite3 -e VUL_IP=xxx.xxx.xxx.xxx vulfocus/vulfocus:latest
docker start container_id
注意:当第一次使用docker create -p 80:80 -v /var/run/docker.sock:/var/run/docker.sock -v /xxx/db.sqlite3:/vulfocus-api/db.sqlite3 -e VUL_IP=xxx.xxx.xxx.xxx vulfocus/vulfocus:latest 时必须要保证/xxx/db.sqlite3是从GitHub上下载的最新数据库,否则容器运行将会抛出服务器内部错误
自定义安装数据库迁移报错
进入项目所在的目录的vulfocus-api文件夹目录下,执行下面命令
rm -rf $(find ./**/migrations/00*)
执行命令
python3 manage.py makemigrations
python3 manage.py migrate --fake
若经过上面步骤如果数据库迁移还是报错,请检查数据库是否与文件夹下的迁移记录产生冲突,可用数据库连接工具检查数据库的表结构
场景无法下载
目前官网的所有场景支持压缩包方式构建,构建步骤如下
- 进入场景管理/环境编排管理,点击添加场景,选择创建编排模式
2.点击上传,选中要构建的场景压缩包(压缩包暂不支持普通用户下载,可联系系统管理员下载)
3.上传成功后点击保存
4.这时可在环境编排管理界面看见新上传的场景,点击发布并且发布成功后即可使用(发布的过程会下载场景所需镜像,等待镜像下载完毕即可)
5.发布成功后即可在场景处看见新的场景
如何设置镜像运行时长
在系统管理/系统配置处可修改镜像的运行时长
镜像一键同步报错
- 自定义安装
修改项目目录下的vulfocus-api/dockerapi/views.py文件,修改get_timing_imgs函数,将vulfocus.fofa.so替换成vulfocus.io
-
docker镜像启动
1.将容器内部的/vulfocus-api/dockerapi/views.py文件拷贝至主机当前目录
修改当前目录下拷贝出来的views.py文件,修改get_timing_imgs函数,将vulfocus.fofa.so替换成vulfocus.io
将修改好的views文件重新copy至容器内部
Contributors
Thanks goes to these wonderful people :