Opened 13 years ago

Closed 13 years ago

#967 closed defect (fixed)

Security: GN vulnerable to XML bombs

Reported by: heikki Owned by: heikki
Priority: major Milestone: v2.8.0 RC1
Component: General Version: v2.6.4
Keywords: security, xml bomb, DTD Cc:

Description

Michael Östling reports:

Geonetwork has a security missconfiguration problem caused by the
 same reason as mentioned before: DTD directives are allowed in 
XML documents loaded by the user. This makes possible to perform 
a kind of access attack calls “XML bomb”.

A XML bomb makes use of the way that a XML processor manages 
entities in the XML document. In the process of replacing entities 
with the strings that they refer XML parser needs to hold these 
strings in memory. An attacker can make use of this behaviour to 
vreate entities that use a lot of memory and then refer them, which
 leads to memory leak in the system that XML parser is running..

Avoid DTD-directives in the incoming XML document.

References:
http://msdn.microsoft.com/en-us/magazine/ee335713.aspx

The fix, which only works if you're running JDK 1.6, is to set FEATURE_SECURE_PROCESSING to true when creating SAXBuilder.

This sets a maximum number of DTD Entity expansions, and if the DTD exceeds the limit an exception is thrown. If this limit proves too restrictive it is possible to increase it using the System Property on the Java command line such as -DentityExpansionLimit=500000 (but it's difficult to imagine this would ever be necessary).

We do not disallow DTDs altogether as some metadata formats may use DTD.

Change History (1)

comment:1 by heikki, 13 years ago

Milestone: v2.6.5v2.8.0 RC1
Resolution: fixed
Status: newclosed

Committed to master and 2.8.x : 6957a6200f9cc9894cc2f2642579cacc02f8b463 Backported to 2.6.x. : 7096569361b9e04857d7b4a5f0d6dfd3e494752c

Note: See TracTickets for help on using tickets.