<div class="markdown-body editormd-preview-container" previewcontainer="true" style="padding: 20px;"><div class="markdown-toc editormd-markdown-toc"><ul class="markdown-toc-list"><li><a class="toc-level-2" href="#套娃" level="2">套娃</a></li><li><a class="toc-level-2" href="#睿智题目" level="2">睿智题目</a></li><li><a class="toc-level-2" href="#给你一雪球" level="2">给你一雪球</a></li><li><a class="toc-level-2" href="#PHP" level="2">PHP</a></li><li><a class="toc-level-2" href="#给我我最喜欢的数字" level="2">给我我最喜欢的数字</a></li><li><a class="toc-level-2" href="#Morse" level="2">Morse</a></li><li><a class="toc-level-2" href="#代码审计" level="2">代码审计</a></li><li><a class="toc-level-2" href="#login" level="2">login</a></li><li><a class="toc-level-2" href="#local" level="2">local</a></li><li><a class="toc-level-2" href="#justarar" level="2">justarar</a></li><li><a class="toc-level-2" href="#JSFUCK" level="2">JSFUCK</a></li><li><a class="toc-level-2" href="#JSFUCK2" level="2">JSFUCK2</a></li><li><a class="toc-level-2" href="#隐匿的真相" level="2">隐匿的真相</a></li><li><a class="toc-level-2" href="#head" level="2">head</a></li><li><a class="toc-level-2" href="#hctf_2018_warmup" level="2">hctf_2018_warmup</a></li><li><a class="toc-level-2" href="#你被黑了！" level="2">你被黑了！</a></li><li><a class="toc-level-2" href="#与佛论禅" level="2">与佛论禅</a></li><li><a class="toc-level-2" href="#Filter" level="2">Filter</a></li><li><a class="toc-level-2" href="#exec" level="2">exec</a></li><li><a class="toc-level-2" href="#exec2" level="2">exec2</a></li><li><a class="toc-level-2" href="#ex~" level="2">ex~</a></li><li><a class="toc-level-2" href="#ereg" level="2">ereg</a></li><li><a class="toc-level-2" href="#低头" level="2">低头</a></li><li><a class="toc-level-2" href="#鸡你太美" level="2">鸡你太美</a></li><li><a class="toc-level-2" href="#color" level="2">color</a></li><li><a class="toc-level-2" href="#相机" level="2">相机</a></li><li><a class="toc-level-2" href="#302" level="2">302</a></li><li><a class="toc-level-2" href="#Filter2" level="2">Filter2</a></li><li><a class="toc-level-2" href="#内有乾坤" level="2">内有乾坤</a></li><li><a class="toc-level-2" href="#回转" level="2">回转</a><ul></ul></li></ul></div><h2 id="h2-u5957u5A03"><a name="套娃" class="reference-link"></a><span class="header-link octicon octicon-link"></span>套娃</h2><ol>
<li><p>进入发现是一张图片，上面写着图片？，猜测可能藏了东西<br><img src="https://nc0.cdn.zkaq.cn/md/11066/858c97a37eeb52b42cbecbdf843da084_40216.png" alt=""></p>
</li><li><p>右键另存为图片，拖进kali虚拟机，使用binwalk检测一下<br><img src="https://nc0.cdn.zkaq.cn/md/11066/fe32c95051873462c0f9e25f95e89896_39931.png" alt=""></p>
</li><li><p>果然还藏了个7-zip，重命名图片，后缀改为.7z，打开获得flag</p>
</li></ol>
<h2 id="h2-u777Fu667Au9898u76EE"><a name="睿智题目" class="reference-link"></a><span class="header-link octicon octicon-link"></span>睿智题目</h2><ol>
<li><p>进入发现一直循环弹两个窗，题如其名，确实睿智<br><img src="https://nc0.cdn.zkaq.cn/md/11066/252f9f4c3e8edd172f73d32248a53d31_29363.png" alt=""></p>
</li><li><p>打开burp，重新访问页面抓包，没什么发现</p>
</li><li><p>查看响应包，发现一段HTML编码过的数据，复制解码获得flag<br><img src="https://nc0.cdn.zkaq.cn/md/11066/99c0b9cc4269c8e2247607dae58ae179_50705.png" alt=""></p>
</li></ol>
<h2 id="h2-u7ED9u4F60u4E00u96EAu7403"><a name="给你一雪球" class="reference-link"></a><span class="header-link octicon octicon-link"></span>给你一雪球</h2><ol>
<li><p>进入发现是一个小萝莉给你丢个了雪球，雪球上是一个二维码，黑白颜色不明显，并且仔细观察会发现右半部分的二维码被进行过反色处理<br><img src="https://nc0.cdn.zkaq.cn/md/11066/6f7aa2ae266a6c5ee8491d2109c8f81f_32340.png" alt=""></p>
</li><li><p>右键另存为，使用Photoshop打开，图像-&gt;调整-&gt;色阶，调整到90-120<br><img src="https://nc0.cdn.zkaq.cn/md/11066/38cab2453ccc4538290971d13cf1c9a1_22994.png" alt=""></p>
</li><li><p>框选二维码右半部分，图像-&gt;调整-&gt;反相，得到原二维码，扫描获得flag<br><img src="https://nc0.cdn.zkaq.cn/md/11066/62dff4cadac070fcd648f018e1588d0e_77798.png" alt=""></p>
</li></ol>
<h2 id="h2-php"><a name="PHP" class="reference-link"></a><span class="header-link octicon octicon-link"></span>PHP</h2><ol>
<li><p>进入发现是一段代码<br><img src="https://nc0.cdn.zkaq.cn/md/11066/5a760dce7c4db728d93f48a59c734840_98833.png" alt=""></p>
</li><li><p>审计后不难发现，第一层，a[]=1&amp;b[]=2，第二层，key={“key”:0}</p>
</li><li>payload: <code>?a[]=1&amp;b[]=2&amp;key={"key":0}</code><br><img src="https://nc0.cdn.zkaq.cn/md/11066/a6eb4eb4df48961c1ad259104c2b109f_10547.png" alt=""></li></ol>
<h2 id="h2-u7ED9u6211u6211u6700u559Cu6B22u7684u6570u5B57"><a name="给我我最喜欢的数字" class="reference-link"></a><span class="header-link octicon octicon-link"></span>给我我最喜欢的数字</h2><ol>
<li><p>进来发现一张图和一个框，测试发现没啥用，F12发现有一个txt文件<br><img src="https://nc0.cdn.zkaq.cn/md/11066/74e76291b1a692b79128aa49b920306f_31896.png" alt=""></p>
</li><li><p>访问发现是index.php的源码<br><img src="https://nc0.cdn.zkaq.cn/md/11066/a09067c6698a2d7dbea72f040cada207_82675.png" alt=""></p>
</li><li><p>此时针对于该php代码进行分析，这里需要绕过两个if语句，第一个是检测POST传入的参数必须是存在，第二传入的POST必须为包括数字(1-9）组成的数字，同时要输出flag。strpos检测num中的#testaasafd必须返回true。那么逐步尝试发送可以使用%00进行截断，可以使用burp抓包修改也可以使用hackbar进行传值</p>
</li><li><p>Payload：<code>num=1%00#testaasafd</code><br><img src="https://nc0.cdn.zkaq.cn/md/11066/2bba5070716c7e86fc468cd08f346071_34257.png" alt=""></p>
</li></ol>
<h2 id="h2-morse"><a name="Morse" class="reference-link"></a><span class="header-link octicon octicon-link"></span>Morse</h2><ol>
<li><p>打开题目发现提示，flag就在这，flag格式zKaQ{xxxx}，F12发现一段摩斯密码<br><img src="https://nc0.cdn.zkaq.cn/md/11066/6e54e8cdce048f4f30ff830c35f48f82_80024.png" alt=""></p>
</li><li><p>复制解码，在线解码：<a href="https://www.bejson.com/enc/morse/">https://www.bejson.com/enc/morse/</a></p>
</li><li><p>解出一段疑似MD5加密的值，先提交看看，题目也提示了格式，zKaQ{xxxx}，提交发现flag正确</p>
</li></ol>
<h2 id="h2-u4EE3u7801u5BA1u8BA1"><a name="代码审计" class="reference-link"></a><span class="header-link octicon octicon-link"></span>代码审计</h2><ol>
<li><p>进来发现两段相同的md5值，测试没发现什么有用的信息，试试目录扫描<br><img src="https://nc0.cdn.zkaq.cn/md/11066/2416fd53a25f11cbb2f43377bcc2fe09_97601.png" alt=""></p>
</li><li><p>发现flag.php，访问没东西，下载index.php.bak，打开是index.php源码<br><img src="https://nc0.cdn.zkaq.cn/md/11066/c04ef37a37db34185d19d8a830bd311d_20113.png" alt=""></p>
</li><li><p><code>strstr($_SERVER['REQUEST_URI'], '?');</code>//截取?后面的值，所以这里我们可以用kekeyy绕过第一个过滤;然后在用数组绕过第二个过滤，因为md5()函数无法处理数组</p>
</li><li><p>Payload：<code>?kekeyy1[]=a&amp;kekeyy2[]=b</code></p>
</li></ol>
<h2 id="h2-login"><a name="login" class="reference-link"></a><span class="header-link octicon octicon-link"></span>login</h2><ol>
<li><p>进来发现让登录，SQL注入发现无果，随便敲个账号密码提示不是管理员，admin，admin提示密码错误</p>
</li><li><p>爆破也无果，F12发现一段base64编码<br><img src="https://nc0.cdn.zkaq.cn/md/11066/5cf5f76c63ce8252693ddd942050a51a_64209.png" alt=""></p>
</li><li><p>解码为zKaQZkAq，尝试登录，提示IP禁止访问<br><img src="https://nc0.cdn.zkaq.cn/md/11066/fb52cb3b87a558593381cd1635b1ecd7_77718.png" alt=""></p>
</li><li><p>head添加X-Forwarded-For: 127.0.0.1，登录得到flag</p>
</li></ol>
<h2 id="h2-local"><a name="local" class="reference-link"></a><span class="header-link octicon octicon-link"></span>local</h2><ol>
<li><p>打开题目提示仅限本地访问！</p>
</li><li><p>head添加x-forwarded-for: 127.0.0.1，无果，head添加Client-Ip: 127.0.0.1 再次访问，得到flag<br><img src="https://nc0.cdn.zkaq.cn/md/11066/2fb2904a7508d3d036bf19856cc83fe0_90545.png" alt=""></p>
</li></ol>
<h2 id="h2-justarar"><a name="justarar" class="reference-link"></a><span class="header-link octicon octicon-link"></span>justarar</h2><ol>
<li><p>打开题目发现让我们下载附件，下载下来是一个rar，根据提示，密码四位数字，用ARCHPR爆破压缩包密码得到密码2016</p>
</li><li><p>最后得到一张图片，查看hex，在里面找到flag，去掉空格提交，flag正确<br><img src="https://nc0.cdn.zkaq.cn/md/11066/1ca729f781a1d474fcbfa7bab426ba20_87816.png" alt=""></p>
</li></ol>
<h2 id="h2-jsfuck"><a name="JSFUCK" class="reference-link"></a><span class="header-link octicon octicon-link"></span>JSFUCK</h2><ol>
<li><p>进来发现一段提示和一个输入框，输入框测试无果，试试目录扫描<br><img src="https://nc0.cdn.zkaq.cn/md/11066/736360a5ceefa9f0f783c9b70effb367_49256.png" alt=""></p>
</li><li><p>发现index.php.bak文件，下载下来发现一段JSFUCK编码<br><img src="https://nc0.cdn.zkaq.cn/md/11066/a5ec3adfb15b4a75d9e0b6c21a590909_79987.png" alt=""></p>
</li><li><p>解码以后发现又是一个新的编码，之前index.php.bak文件中提示key为ZKAQ，试试AES解密，得到flag<br><img src="https://nc0.cdn.zkaq.cn/md/11066/cc3292dbe5ade0166add366bf3ebdc49_35794.png" alt=""></p>
</li></ol>
<h2 id="h2-jsfuck2"><a name="JSFUCK2" class="reference-link"></a><span class="header-link octicon octicon-link"></span>JSFUCK2</h2><ol>
<li><p>进来发现一句话，要我点他，这辈子没见过这么嚣张的人，点他！</p>
</li><li><p>点完发现下载了一个压缩包，打开发现是一堆JSFUCK密文，尝试解密。<br><img src="https://nc0.cdn.zkaq.cn/md/11066/784ab81aac1f691ea62fb488e617ae3a_31708.png" alt=""></p>
</li><li><p>看着头大，算了，直接甩F12，console执行一下看看<br><img src="https://nc0.cdn.zkaq.cn/md/11066/de6c130c10a385846368a23bdbdf5c3f_83559.png" alt=""></p>
</li><li><p>OK，成功拿到flag</p>
</li></ol>
<h2 id="h2-u9690u533Fu7684u771Fu76F8"><a name="隐匿的真相" class="reference-link"></a><span class="header-link octicon octicon-link"></span>隐匿的真相</h2><ol>
<li><p>打开发现也是要下载附件，我们下载下来发现是一个Word文档</p>
</li><li><p>进来直接Ctrl + A全选，找个地方粘贴出来，就可以拿到flag了<br><img src="https://nc0.cdn.zkaq.cn/md/11066/7939b066efd54fe1cd32ec0a3a0f2b16_92977.png" alt=""></p>
</li></ol>
<h2 id="h2-head"><a name="head" class="reference-link"></a><span class="header-link octicon octicon-link"></span>head</h2><ol>
<li><p>题目是head，猜测应该在head可以找到有用信息，burp抓包，未发现有用信息</p>
</li><li><p>F12-&gt;Network，刷新页面，在响应包中找到flag，也可以用burp抓响应包<br><img src="https://nc0.cdn.zkaq.cn/md/11066/61fa069c3a44f5337c7b19760f7a4db9_62789.png" alt=""></p>
</li></ol>
<h2 id="h2-hctf_2018_warmup"><a name="hctf_2018_warmup" class="reference-link"></a><span class="header-link octicon octicon-link"></span>hctf_2018_warmup</h2><ol>
<li><p>访问页面查看源码发现注释里面的内容访问它<br><img src="https://nc0.cdn.zkaq.cn/md/11066/81d834c702b28c9d47bd6baadb5deebb_28885.png" alt=""></p>
</li><li><p>访问发现源码<br><img src="https://nc0.cdn.zkaq.cn/md/11066/e8fa6dacc4e1b3bfc6a4fdaa68614cc9_72183.png" alt=""></p>
</li><li><p>发现hint.php 打开看到提示，flag在ffffllllaaaagggg<br><img src="https://nc0.cdn.zkaq.cn/md/11066/cdaad8b663e2423557d39d836522405f_28777.png" alt=""></p>
</li><li><p>分析一下源码</p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pun">&lt;?</span><span class="pln">php</span></code></li><li class="L1"><code><span class="pln">    highlight_file</span><span class="pun">(</span><span class="pln">__FILE__</span><span class="pun">);</span></code></li><li class="L2"><code><span class="pln">    </span><span class="kwd">class</span><span class="pln"> emmm</span></code></li><li class="L3"><code><span class="pln">    </span><span class="pun">{</span></code></li><li class="L4"><code><span class="pln">        </span><span class="kwd">public</span><span class="pln"> </span><span class="kwd">static</span><span class="pln"> </span><span class="kwd">function</span><span class="pln"> checkFile</span><span class="pun">(&amp;</span><span class="pln">$page</span><span class="pun">)</span></code></li><li class="L5"><code><span class="pln">        </span><span class="pun">{</span><span class="com">//白名单列表</span></code></li><li class="L6"><code><span class="pln">            $whitelist </span><span class="pun">=</span></code></li><li class="L7"><code><span class="pln">             </span><span class="pun">[</span><span class="str">"source"</span><span class="pun">=&gt;</span><span class="str">"source.php"</span><span class="pun">,</span><span class="str">"hint"</span><span class="pun">=&gt;</span><span class="str">"hint.php"</span><span class="pun">];</span></code></li><li class="L8"><code><span class="pln"> </span><span class="com">//isset()判断变量是否声明 is_string()判断变量是否是字符串 </span></code></li><li class="L9"><code><span class="pln">            </span><span class="kwd">if</span><span class="pln"> </span><span class="pun">(!</span><span class="pln"> isset</span><span class="pun">(</span><span class="pln">$page</span><span class="pun">)</span><span class="pln"> </span><span class="pun">||</span><span class="pln"> </span><span class="pun">!</span><span class="pln">is_string</span><span class="pun">(</span><span class="pln">$page</span><span class="pun">))</span></code></li><li class="L0"><code><span class="pln">                </span><span class="com">//如果变量声明且为字符串才不会判别为真</span></code></li><li class="L1"><code><span class="pln">            </span><span class="pun">{</span></code></li><li class="L2"><code><span class="pln">                echo </span><span class="str">"you can't see it"</span><span class="pun">;</span></code></li><li class="L3"><code><span class="pln">                </span><span class="kwd">return</span><span class="pln"> </span><span class="kwd">false</span><span class="pun">;</span></code></li><li class="L4"><code><span class="pln">            </span><span class="pun">}</span><span class="com">//不返回值</span></code></li><li class="L5"><code></code></li><li class="L6"><code><span class="pln">            </span><span class="kwd">if</span><span class="pln"> </span><span class="pun">(</span><span class="pln">in_array</span><span class="pun">(</span><span class="pln">$page</span><span class="pun">,</span><span class="pln"> $whitelist</span><span class="pun">))</span><span class="pln"> </span><span class="pun">{</span></code></li><li class="L7"><code><span class="pln">                </span><span class="kwd">return</span><span class="pln"> </span><span class="kwd">true</span><span class="pun">;</span></code></li><li class="L8"><code><span class="pln">            </span><span class="pun">}</span><span class="com">//白名单判断，是hint或source返回真</span></code></li><li class="L9"><code><span class="com">/*</span></code></li><li class="L0"><code><span class="com">mb_strpos()：返回要查找的字符串在别一个字符串中首次出现的位置</span></code></li><li class="L1"><code><span class="com">mb_strpos (haystack ,needle )</span></code></li><li class="L2"><code><span class="com">haystack：要被检查的字符串。</span></code></li><li class="L3"><code><span class="com">needle：要搜索的字符串</span></code></li><li class="L4"><code><span class="com">*/</span></code></li><li class="L5"><code><span class="pln">            </span><span class="com">//？截断   截取page变量从开头到？</span></code></li><li class="L6"><code><span class="pln">            $_page </span><span class="pun">=</span><span class="pln"> mb_substr</span><span class="pun">(</span></code></li><li class="L7"><code><span class="pln">                $page</span><span class="pun">,</span></code></li><li class="L8"><code><span class="pln">                </span><span class="lit">0</span><span class="pun">,</span></code></li><li class="L9"><code><span class="pln">                mb_strpos</span><span class="pun">(</span><span class="pln">$page </span><span class="pun">.</span><span class="pln"> </span><span class="str">'?'</span><span class="pun">,</span><span class="pln"> </span><span class="str">'?'</span><span class="pun">)</span></code></li><li class="L0"><code><span class="pln">            </span><span class="pun">);</span></code></li><li class="L1"><code><span class="pln">            </span><span class="kwd">if</span><span class="pln"> </span><span class="pun">(</span><span class="pln">in_array</span><span class="pun">(</span><span class="pln">$_page</span><span class="pun">,</span><span class="pln"> $whitelist</span><span class="pun">))</span><span class="pln"> </span><span class="pun">{</span></code></li><li class="L2"><code><span class="pln">                </span><span class="kwd">return</span><span class="pln"> </span><span class="kwd">true</span><span class="pun">;</span></code></li><li class="L3"><code><span class="pln">            </span><span class="pun">}</span><span class="com">//白名单检查</span></code></li><li class="L4"><code></code></li><li class="L5"><code><span class="pln">            $_page </span><span class="pun">=</span><span class="pln"> urldecode</span><span class="pun">(</span><span class="pln">$page</span><span class="pun">);</span><span class="com">//url解码</span></code></li><li class="L6"><code><span class="pln">            $_page </span><span class="pun">=</span><span class="pln"> mb_substr</span><span class="pun">(</span></code></li><li class="L7"><code><span class="pln">                $_page</span><span class="pun">,</span></code></li><li class="L8"><code><span class="pln">                </span><span class="lit">0</span><span class="pun">,</span></code></li><li class="L9"><code><span class="pln">                mb_strpos</span><span class="pun">(</span><span class="pln">$_page </span><span class="pun">.</span><span class="pln"> </span><span class="str">'?'</span><span class="pun">,</span><span class="pln"> </span><span class="str">'?'</span><span class="pun">)</span></code></li><li class="L0"><code><span class="pln">            </span><span class="pun">);</span><span class="com">//二次截断</span></code></li><li class="L1"><code><span class="pln">            </span><span class="kwd">if</span><span class="pln"> </span><span class="pun">(</span><span class="pln">in_array</span><span class="pun">(</span><span class="pln">$_page</span><span class="pun">,</span><span class="pln"> $whitelist</span><span class="pun">))</span><span class="pln"> </span><span class="pun">{</span></code></li><li class="L2"><code><span class="pln">                </span><span class="kwd">return</span><span class="pln"> </span><span class="kwd">true</span><span class="pun">;</span></code></li><li class="L3"><code><span class="pln">            </span><span class="pun">}</span><span class="com">//第三次白名单检查</span></code></li><li class="L4"><code><span class="pln">            echo </span><span class="str">"you can't see it"</span><span class="pun">;</span></code></li><li class="L5"><code><span class="pln">            </span><span class="kwd">return</span><span class="pln"> </span><span class="kwd">false</span><span class="pun">;</span></code></li><li class="L6"><code><span class="pln">        </span><span class="pun">}</span></code></li><li class="L7"><code><span class="pln">    </span><span class="pun">}</span></code></li><li class="L8"><code></code></li><li class="L9"><code><span class="pln">    </span><span class="kwd">if</span><span class="pln"> </span><span class="pun">(!</span><span class="pln"> empty</span><span class="pun">(</span><span class="pln">$_REQUEST</span><span class="pun">[</span><span class="str">'file'</span><span class="pun">])</span></code></li><li class="L0"><code><span class="pln">        </span><span class="pun">&amp;&amp;</span><span class="pln"> is_string</span><span class="pun">(</span><span class="pln">$_REQUEST</span><span class="pun">[</span><span class="str">'file'</span><span class="pun">])</span></code></li><li class="L1"><code><span class="pln">        </span><span class="pun">&amp;&amp;</span><span class="pln"> emmm</span><span class="pun">::</span><span class="pln">checkFile</span><span class="pun">(</span><span class="pln">$_REQUEST</span><span class="pun">[</span><span class="str">'file'</span><span class="pun">])</span></code></li><li class="L2"><code><span class="pln">    </span><span class="pun">)</span><span class="pln"> </span><span class="pun">{</span></code></li><li class="L3"><code><span class="pln">        include $_REQUEST</span><span class="pun">[</span><span class="str">'file'</span><span class="pun">];</span></code></li><li class="L4"><code><span class="pln">        </span><span class="kwd">exit</span><span class="pun">;</span></code></li><li class="L5"><code><span class="pln">    </span><span class="pun">}</span><span class="pln"> </span><span class="kwd">else</span><span class="pln"> </span><span class="pun">{</span></code></li><li class="L6"><code><span class="pln">        echo </span><span class="str">"&lt;br&gt;&lt;img src=\"5bdb0d93dc794.jpg\" /&gt;"</span><span class="pun">;</span></code></li><li class="L7"><code><span class="pln">    </span><span class="pun">}</span><span class="pln">  </span></code></li><li class="L8"><code><span class="pun">?&gt;</span></code></li></ol></pre></li><li><p>需要满足经过两次？截断后仍能通过白名单检查，并且include正确路径，才输出flag。</p>
<p>构建payload: <code>source.php?file=hint.php?../../../../../../../../ffffllllaaaagggg</code></p>
<p>解释一下这段payload，checkfile检测传入的file的值，将file赋给page变量，首先白名单检测hint.php在白名单内返回真。</p>
<p>然后？截断在第一次截断的时候将file中的hint.php?../../../../../../../../ffffllllaaaagggg截断为hint.php并顺利通过第二次白名单检测。</p>
<p>接着是一次url解码，将page变量进行一次url解码。</p>
<p>注意</p>
<p><code>mb_strpos($_page . '?', '?')</code></p>
<p>这段代码，“$_page . ‘?’,”，中的那个.是一个连接符，相当于在__page变量后加上一个？。于是这次同样截断剩下hint.php再次顺利通过白名单检测。最后满足3个if条件执行include语句。在包含的时候会把hint.php?/当成一层目录，然后构造../../向上遍历找到flag。</p>
<p>因为白名单有两个字符串所以把file里面的hint换成source也是一样能拿到flag。</p>
<p>即<code>source.php?file=source.php?../../../../../../../../ffffllllaaaagggg</code>可以达到相同的效果。</p>
</li></ol>
<h2 id="h2--"><a name="你被黑了！" class="reference-link"></a><span class="header-link octicon octicon-link"></span>你被黑了！</h2><ol>
<li><p>进来发现是一张图，网站标题显示：你被黑啦！<br><img src="https://nc0.cdn.zkaq.cn/md/11066/6914b840fbc82c8c0b20cc3289d09570_88530.png" alt=""></p>
</li><li><p>检查源码无果，扫一下目录，发现有一个webshell.php，访问看看<br><img src="https://nc0.cdn.zkaq.cn/md/11066/d3de34517f80f5c517c20eab7e4d140b_81149.png" alt=""></p>
</li><li><p>发现是个是个表单，随便输入提示<br><img src="https://nc0.cdn.zkaq.cn/md/11066/d0d4cdd1e079b13e3b4b89aae3b345c9_22366.png" alt=""></p>
</li><li><p>使用burp爆破，密码是：a123456789，拿到flag。</p>
</li></ol>
<h2 id="h2-u4E0Eu4F5Bu8BBAu7985"><a name="与佛论禅" class="reference-link"></a><span class="header-link octicon octicon-link"></span>与佛论禅</h2><ol>
<li><p>进来发现是一段文字，我们暂时忽略劲夫是怎么奖励自己的，我们只抓住重点，那段奇奇怪怪的文字</p>
</li><li><p>题目是与佛论禅，那我们去解密一下，在线网站：<a href="https://www.keyfc.net/bbs/tools/tudoucode.aspx">https://www.keyfc.net/bbs/tools/tudoucode.aspx</a></p>
</li><li><p>解密以后成功拿到flag。是不是很简单？<br><img src="https://nc0.cdn.zkaq.cn/md/11066/f4d88c0382ca8a58265c738b576a34f3_47655.png" alt=""></p>
</li></ol>
<h2 id="h2-filter"><a name="Filter" class="reference-link"></a><span class="header-link octicon octicon-link"></span>Filter</h2><ol>
<li><p>进来后发现一个超链接，点击发现url产生变化，猜测是文件包含<br><img src="https://nc0.cdn.zkaq.cn/md/11066/f5bad89d82a26e389c56e590ec3bc05b_95611.png" alt=""></p>
</li><li><p>目录扫描没什么收获，尝试使用PHP伪协议读取一下index.php。</p>
<p>Payload：<code>?file=php://filter/read=convert.base64-encode/resource=index.php</code></p>
</li><li><p>获得index.php经过base64编码以后的源码，解码以后在注释中找到flag。<br><img src="https://nc0.cdn.zkaq.cn/md/11066/133f7a87a1d3a2d4ade570e21719e0e6_75260.png" alt=""></p>
</li></ol>
<h2 id="h2-exec"><a name="exec" class="reference-link"></a><span class="header-link octicon octicon-link"></span>exec</h2><ol>
<li><p>进来查看网页源码发现提示source传参，传参以后出现图片，里面是源码<br><img src="https://nc0.cdn.zkaq.cn/md/11066/6b4ab2a5a29013f44f4ff54a92681e5d_65675.png" alt=""></p>
</li><li><p>源码：</p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code class="lang-php"><span class="pun">&lt;?</span><span class="pln">php </span></code></li><li class="L1"><code class="lang-php"></code></li><li class="L2"><code class="lang-php"><span class="pln">$ip </span><span class="pun">=</span><span class="pln"> isset</span><span class="pun">(</span><span class="pln">$_POST</span><span class="pun">[</span><span class="str">'ip'</span><span class="pun">])?</span><span class="pln">$_POST</span><span class="pun">[</span><span class="str">'ip'</span><span class="pun">]:</span><span class="kwd">die</span><span class="pun">();</span></code></li><li class="L3"><code class="lang-php"></code></li><li class="L4"><code class="lang-php"><span class="kwd">if</span><span class="pun">(!</span><span class="pln">preg_match</span><span class="pun">(</span><span class="str">'/^\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}/i'</span><span class="pun">,</span><span class="pln">$ip</span><span class="pun">)){</span></code></li><li class="L5"><code class="lang-php"><span class="pln">    </span><span class="kwd">die</span><span class="pun">(</span><span class="str">"ip 格式错误!"</span><span class="pun">);</span></code></li><li class="L6"><code class="lang-php"><span class="pun">}</span></code></li><li class="L7"><code class="lang-php"></code></li><li class="L8"><code class="lang-php"><span class="pln">echo strlen</span><span class="pun">(</span><span class="pln">$ip</span><span class="pun">);</span></code></li><li class="L9"><code class="lang-php"></code></li><li class="L0"><code class="lang-php"><span class="kwd">if</span><span class="pun">(</span><span class="pln">strlen</span><span class="pun">(</span><span class="pln">$ip</span><span class="pun">)&lt;</span><span class="lit">7</span><span class="pun">||</span><span class="pln">strlen</span><span class="pun">(</span><span class="pln">$ip</span><span class="pun">)&gt;</span><span class="lit">21</span><span class="pun">){</span></code></li><li class="L1"><code class="lang-php"><span class="pln">    </span><span class="kwd">die</span><span class="pun">(</span><span class="str">"ip 长度错误!"</span><span class="pun">);</span></code></li><li class="L2"><code class="lang-php"><span class="pun">}</span></code></li><li class="L3"><code class="lang-php"></code></li><li class="L4"><code class="lang-php"><span class="com">// Determine OS and execute the ping command.</span></code></li><li class="L5"><code class="lang-php"><span class="kwd">if</span><span class="pun">(</span><span class="pln"> stristr</span><span class="pun">(</span><span class="pln"> php_uname</span><span class="pun">(</span><span class="pln"> </span><span class="str">'s'</span><span class="pln"> </span><span class="pun">),</span><span class="pln"> </span><span class="str">'Windows NT'</span><span class="pln"> </span><span class="pun">)</span><span class="pln"> </span><span class="pun">)</span><span class="pln"> </span><span class="pun">{</span></code></li><li class="L6"><code class="lang-php"><span class="com">// Windows</span></code></li><li class="L7"><code class="lang-php"></code></li><li class="L8"><code class="lang-php"><span class="pln">$cmd </span><span class="pun">=</span><span class="pln"> shell_exec</span><span class="pun">(</span><span class="pln"> </span><span class="str">'ping  '</span><span class="pln"> </span><span class="pun">.</span><span class="pln">$ip </span><span class="pun">);</span></code></li><li class="L9"><code class="lang-php"><span class="pun">}</span><span class="kwd">else</span><span class="pln"> </span><span class="pun">{</span></code></li><li class="L0"><code class="lang-php"><span class="com">// *nix</span></code></li><li class="L1"><code class="lang-php"><span class="pln">$cmd </span><span class="pun">=</span><span class="pln"> shell_exec</span><span class="pun">(</span><span class="pln"> </span><span class="str">'ping  -c 1 '</span><span class="pln"> </span><span class="pun">.</span><span class="pln">$ip </span><span class="pun">);</span></code></li><li class="L2"><code class="lang-php"><span class="pun">}</span></code></li><li class="L3"><code class="lang-php"></code></li><li class="L4"><code class="lang-php"><span class="com">// Feedback for the end user</span></code></li><li class="L5"><code class="lang-php"><span class="pln">echo  </span><span class="str">"&lt;pre&gt;{$cmd}&lt;/pre&gt;"</span><span class="pun">;</span></code></li></ol></pre>
</li><li><p>无字符过滤，post传参，对IP格式检测，还有限制长度，先查看一下根目录 <code>ip=127.0.0.1;ls /</code><br><img src="https://nc0.cdn.zkaq.cn/md/11066/90b2b5d50fcda055d2ec8aa6e18d0238_93856.png" alt=""></p>
</li><li><p>发现有个ffffllllaaaagggg文件，直接读取肯定是不行的超过长度了，但我们可以使用通配符<code>ip=127.0.0.1;cat /f*</code><br><img src="https://nc0.cdn.zkaq.cn/md/11066/3c36f17a562affd90b59d7d1c9c9e3d2_96393.png" alt=""></p>
</li></ol>
<h2 id="h2-exec2"><a name="exec2" class="reference-link"></a><span class="header-link octicon octicon-link"></span>exec2</h2><ol>
<li>进来发现源码</li></ol>
<p><img src="https://nc0.cdn.zkaq.cn/md/11066/fa26254f8f5bb1820962d549b97f384c_53962.png" alt=""></p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code class="lang-php"><span class="pln">   $pat1 </span><span class="pun">=</span><span class="pln"> </span><span class="str">"/[^0-9a-zA-Z \/\*]/"</span><span class="pun">;</span></code></li><li class="L1"><code class="lang-php"><span class="pln">   </span><span class="kwd">if</span><span class="pln"> </span><span class="pun">(</span><span class="pln">preg_match</span><span class="pun">(</span><span class="pln">$pat1</span><span class="pun">,</span><span class="pln"> $cmd</span><span class="pun">)&gt;</span><span class="lit">0</span><span class="pun">){</span></code></li><li class="L2"><code class="lang-php"><span class="pln">       </span><span class="kwd">die</span><span class="pun">();</span></code></li><li class="L3"><code class="lang-php"><span class="pln">   </span><span class="pun">}</span></code></li><li class="L4"><code class="lang-php"><span class="pln">   $pat2 </span><span class="pun">=</span><span class="pln"> </span><span class="str">"/^[a-zA-Z]+ [0-9a-zA-Z\/\*]+$/"</span><span class="pun">;</span></code></li><li class="L5"><code class="lang-php"><span class="pln">   </span><span class="kwd">if</span><span class="pln"> </span><span class="pun">(</span><span class="pln">preg_match</span><span class="pun">(</span><span class="pln">$pat2</span><span class="pun">,</span><span class="pln"> $cmd</span><span class="pun">)==</span><span class="lit">0</span><span class="pun">){</span></code></li><li class="L6"><code class="lang-php"><span class="pln">       </span><span class="kwd">die</span><span class="pun">();</span></code></li><li class="L7"><code class="lang-php"><span class="pln">   </span><span class="pun">}</span></code></li></ol></pre>
<p>   不能有0-9a-zA-Z /*之外的字符</p>
<p>   字符串以a-zA-Z开头</p>
<p>   中间有空格</p>
<p>   0-9a-zA-Z/*结尾</p>
<p>   构造payload,查看目录</p>
<ol>
<li><p>Payload：<code>?action=cmd&amp;cmd=ls /</code><br><img src="https://nc0.cdn.zkaq.cn/md/11066/f1866f0029918e521f679a23152b79e8_90186.png" alt=""></p>
</li><li><p>发现有一个flag文件，cat读取一下，拿到flag<br><img src="https://nc0.cdn.zkaq.cn/md/11066/7315c4ded9ae543e82a0816bb4709550_57388.png" alt=""></p>
</li></ol>
<h2 id="h2-ex-"><a name="ex~" class="reference-link"></a><span class="header-link octicon octicon-link"></span>ex~</h2><ol>
<li><p>进来发现一段emo文字~，看着好像没什么思路，看一下网页源码发现，这个链接二字居然是超链接<br><img src="https://nc0.cdn.zkaq.cn/md/11066/0b18cdcbe7da6b7d356cd5276a3f2710_44127.png" alt=""></p>
</li><li><p>点击出现一段源码，审计发现可以用数组绕过<br><img src="https://nc0.cdn.zkaq.cn/md/11066/49e74bf1d5d0893472069ab39a61b63a_42023.png" alt=""></p>
</li><li><p>Payload：<code>?v1[]=1&amp;v2[]=2&amp;v3[]=</code><br><img src="https://nc0.cdn.zkaq.cn/md/11066/f1f09a912699aa8821a894db7a61d15b_30756.png" alt=""></p>
</li></ol>
<h2 id="h2-ereg"><a name="ereg" class="reference-link"></a><span class="header-link octicon octicon-link"></span>ereg</h2><ol>
<li><p>进来啥也没有，查看网页源码发现<code>?source</code>提示</p>
</li><li><p>传参出现源码<br><img src="https://nc0.cdn.zkaq.cn/md/11066/daf36001ad6cd6cfb4d37c39b911ed7b_14609.png" alt=""></p>
</li><li><p>审计发现可以采用科学计数法加截断进行绕过，传参<code>password=1e7%00*-*</code>，解析后的<code>1e8%00*-*</code>字符串长度小于8，且<code>1e8&gt;9999999</code><br><img src="https://nc0.cdn.zkaq.cn/md/11066/5bef7dc868a303030b53f9194a7f2b51_38912.png" alt=""></p>
</li><li><p>Payload：<code>?password=1e7%00*-</code>*</p>
</li></ol>
<h2 id="h2-u4F4Eu5934"><a name="低头" class="reference-link"></a><span class="header-link octicon octicon-link"></span>低头</h2><ol>
<li><p>进来是要求解密一段密文<br><img src="https://nc0.cdn.zkaq.cn/md/11066/0972215eecb7ef0b301d7bf15d5d7f0b_28598.png" alt=""></p>
</li><li><p>题目是低头，那咱们低头，看到的是啥？键盘，好的，flag出来了<br><img src="https://nc0.cdn.zkaq.cn/md/11066/89390151c460c746f932c2b321ac87b8_51969.png" alt=""></p>
</li></ol>
<h2 id="h2-u9E21u4F60u592Au7F8E"><a name="鸡你太美" class="reference-link"></a><span class="header-link octicon octicon-link"></span>鸡你太美</h2><ol>
<li><p>进来题目提示了flag的格式，以及要我们下载附件，下载以后是一个压缩包，解压是两张图片<br><img src="https://nc0.cdn.zkaq.cn/md/11066/421a3d85c2567e25181d8e0d45a5467d_36981.png" alt=""></p>
</li><li><p>发现第一张能打开，而第二张无法打开，很明显我们需要在第二张下手，查看hex发现，第二张少了GIF头<br><img src="https://nc0.cdn.zkaq.cn/md/11066/cb2550345728fa3aa6f6e97fe7422d0c_87980.png" alt=""></p>
</li><li><p>那我们把<code>GIF8</code>给他补上去<br><img src="https://nc0.cdn.zkaq.cn/md/11066/b2aad7b448aacb9302f9a787c5668cbc_49221.png" alt=""></p>
</li><li><p>再次打开，发现图片里有一段文字，根据题目提示的flag格式，提交flag。</p>
</li></ol>
<h2 id="h2-color"><a name="color" class="reference-link"></a><span class="header-link octicon octicon-link"></span>color</h2><ol>
<li><p>进来提示flag就在当前页面，F12查看源码，发现一个隐藏的图片<br><img src="https://nc0.cdn.zkaq.cn/md/11066/1658d38affd7d5c9c0b2bf11dff7630b_79227.png" alt=""></p>
</li><li><p>我们把<code>display: none;</code>去掉，图片出来了，右键保存到本地，使用StegSolve打开，换色，得到flag<br><img src="https://nc0.cdn.zkaq.cn/md/11066/7c022095a82ea4da6244d2525cd46ca8_20728.png" alt=""></p>
</li></ol>
<h2 id="h2-u76F8u673A"><a name="相机" class="reference-link"></a><span class="header-link octicon octicon-link"></span>相机</h2><ol>
<li><p>进来发现一张图片，检查页面没什么收获。</p>
</li><li><p>保存到本地，右键属性，详细信息，在照相机一栏找到flag<br><img src="https://nc0.cdn.zkaq.cn/md/11066/4848277cec96e08c0c080bb3cc63869b_74033.png" alt=""></p>
</li></ol>
<h2 id="h2-302"><a name="302" class="reference-link"></a><span class="header-link octicon octicon-link"></span>302</h2><ol>
<li><p>打开题目，有个超链接告诉你flag就在这里，点击却是跳转到了404.php，仔细观察其实会发现原本应该访问的是flag.html，说明被重定向了</p>
</li><li><p>burp抓包，一个一个包放过去，在其中一个包的head中找到了flag<br><img src="https://nc0.cdn.zkaq.cn/md/11066/a55f6eb3f140f68876c2a0d4ba73e155_78252.png" alt=""></p>
</li></ol>
<h2 id="h2-filter2"><a name="Filter2" class="reference-link"></a><span class="header-link octicon octicon-link"></span>Filter2</h2><ol>
<li><p>进来发现有个超链接，点击发现url的变化应该是文件包含，并且页面提示flag在flag.php</p>
</li><li><p>使用伪协议读取一下flag.php，<code>?file=php://filter/read=convert.base64-encode/resource=flag.php</code>，然后base64解码，发现flag是一串摩斯密码，再次解码，得到一段MD5密文，根据题目提示的flag格式提交就行了<br><img src="https://nc0.cdn.zkaq.cn/md/11066/1e92118149d51bf63626a42542192e75_46676.png" alt=""></p>
</li></ol>
<h2 id="h2-u5185u6709u4E7Eu5764"><a name="内有乾坤" class="reference-link"></a><span class="header-link octicon octicon-link"></span>内有乾坤</h2><ol>
<li><p>进来发现是一张图<br><img src="https://nc0.cdn.zkaq.cn/md/11066/77dead761f6fa00098c08033ccccb52e_87012.png" alt=""></p>
</li><li><p>其实这是一段摩斯密码，短的是<code>.</code>长的是<code>-</code>空的是<code>/</code>，得到<code>.-/.-../.--./..../.-/.-../.-/-...</code> </p>
</li><li><p>解码以后根据flag格式提交flag即可</p>
</li></ol>
<h2 id="h2-u56DEu8F6C"><a name="回转" class="reference-link"></a><span class="header-link octicon octicon-link"></span>回转</h2><ol>
<li>进来是一段密文，base64解码无果</li><li>再试试rot13，在线工具：<a href="http://www.mxcz.net/tools/rot13.aspx">http://www.mxcz.net/tools/rot13.aspx</a></li><li>得到一段新的密文<code>RmxhZ0lTdGFud2VpZ3VhbnpoaQ==</code></li><li>再次尝试base64解码，根据题目flag格式，提交flag即可</li></ol>
</div>