You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
|
|
|
|
---
|
|
|
|
|
layout: post
|
|
|
|
|
title: 记一次组织CTF的经历
|
|
|
|
|
tags: [CTF, 记录]
|
|
|
|
|
---
|
|
|
|
|
|
|
|
|
|
不会打我也能搞CTF(:-P)<!--more-->
|
|
|
|
|
|
|
|
|
|
# 起因
|
|
|
|
|
在一年前,我[体验了一次CTF](/2019/12/16/ctf.html),感觉挺有意思的,而且为此我甚至计划做一个以此为基础的[游戏](/2019/12/17/game.html)。可惜人不行了,除了会咕咕咕其他什么都不行。
|
|
|
|
|
想不到就在最近,我不用参加CTF,而是直接去给其他人玩CTF的机会。最近我所在的协会要承包一次CTF的比赛,我作为协会部门的部长,自然也要参与其中。我最擅长的就是运维,所以在这次比赛,我就成为负责维护这次CTF平台的运维了。
|
|
|
|
|
|
|
|
|
|
# 感受
|
|
|
|
|
成为了维护CTF系统的人之后我对CTF的了解更深了,CTF系统的本质就是一个计分板加一台靶机,然后题就那么几种,像Web、PWN这种题需要靶机,其他的Crypto、Reverse、Misc啥的就只需要把题目放到一个文件服务器里就行了。另外计分板也非常的简单,就只需要一个判断结果是不是等于设定好的flag就完事了,然后根据答题情况给分就行了。
|
|
|
|
|
一般正式的赛事中好像flag都是动态的,每一个队伍的flag都不一样,然后每个队伍打的靶机也全部都是用docker隔离开的,像我们举行的这个CTF并不算专业,只能算是比较业余的。
|
|
|
|
|
|
|
|
|
|
# 经历
|
|
|
|
|
在这次CTF中,我本来是不想管平台的事情,如果我来搭建这个平台我可能会选择[CTFd](https://github.com/CTFd/CTFd)作为本次CTF的平台。不过这个CTF在我来之前举办过几次,他们使用的是由Facebook开发的[FBCTF](https://github.com/facebookarchive/fbctf)作为整个比赛的平台。我作为运维,肯定也不会去管程序上的事情,就干脆让他们去搞相关的事情了。
|
|
|
|
|
不过现实证明这是一个错误的决定,这个平台已经不维护了,虽然看起来确实挺好看,但是BUG也多,在这次比赛中给我们维护组带来了不少的压力。就比如说这个平台里的[这一句话](https://github.com/facebookarchive/fbctf/blob/4ec9b6be404fce1bed6d1066fccf10c4255767bb/database/countries.sql#L161),给我们带来了很多麻烦。就这样的短短一句话,搞的正在运行的平台直接被迫停止运行。为什么呢?很简单,因为我所在的学校是中国啊,不允许这样的事情发生……
|
|
|
|
|
另外这个FBCTF也很迷,看代码不过就是普通的PHP而已,但是部署的时候用的软件和方式都和平时不一样。正常来说这种东西一个LEMP或者LAMP就能解决问题,而它非得要一个什么hhvm的环境,不过环境不是我搭的,它用啥我倒是不在乎。然而它的i18n有问题,在[这一行](https://github.com/facebookarchive/fbctf/blob/4ec9b6be404fce1bed6d1066fccf10c4255767bb/src/controllers/IndexController.php#L598)没有加`tr`的那个函数,然后注册的时候显示就会出问题。有问题倒是没关系,大不了改了就行了,可是这个破玩意改了之后居然没反应?我搞了半天都没有搞好,后来发现因为它用了hhvm,这个东西会把php代码编译,然后直接修改代码就啥反应都没有,必须用`hhvm-repo-mode`才能更新代码😓……
|
|
|
|
|
其他的就是数据库,那个部署的人当时居然没改字符集,用的还是拉丁文的字符集,然后存储中文的时候就会各种乱码,怎么搞都搞不回来,不过程序里面好像没有受影响,所以也就算了。
|
|
|
|
|
还有就是领导的新需求,这也算是提前体验公司生活了,领导说要加一个功能,我肯定不会想着去接这个大坑,最后这个任务被派给了我们的PHP老师,不过老师确实专业,花了4个小时最终真的就搞成了,水平确实了的。
|
|
|
|
|
目前这次的比赛还没有结束,不知道还会出什么新的莫名其妙的事情,敬请期待吧~
|