SessionClickAction allows easy DoS attack

Description

SessionClickAction puts request parameters & values into HttpSession. This can lead to OutOfMemoryException

Example: if I post tens of these images (with different param names) on some high-traffic forum, visitors of such forum fill up memory of the target machine:

Environment

Tomcat 6.0.32 + MySQL 5. 6.0.x Revision 87154. Tomcat 6.0.32 + MySQL 5. 6.1.x Revision 87154.

Attachments

1

Activity

Show:

Sophia.Zhang July 2, 2012 at 10:23 PM
Edited

PASSED Manual Testing following the steps in my previous comment.

Reproduced on:
Tomcat 7.0 + MySQL 5. Portal 6.1.0 EE GA1.

After run the script, Console displays OutOfMemoryException error. And the script runs so slow.

Fixed on:
Tomcat 6.0 + MySQL 5. Portal 6.0.x.EE GIT ID: c66f63074decc74f2060464d300455883c70f68d.
Tomcat 7.0 + MySQL 5. Portal 6.1.x.EE GIT ID: 9db5d1166371a6e59e4ee4f7aa421f7e54f936f4.
Tomcat 7.0 + MySQL 5. Portal 6.2.x GIT ID: 43d6b6844cd6f1e71b0b860d66b16a7b24889865.

After fix, the script runs fast and no OutOfMemoryException error in console any more.

Sophia.Zhang June 26, 2012 at 8:40 PM
Edited

Steps to reproduce:
1. Download the attached test.java file.
2. Startup tomcat.
3. Add Web Content Display portlet. Try to put

in web content body(click on source). (This is just an fast way to reproduce by putting huge worlds in the url.)

3. Navigate to the test.java folder and open a command window, use command line "javac test.java" and "java test" to run the script to hit the page repeatly.
4. Wait for the scritp run.
5. After a while you will see Out of memory error displays in console. For 6012EE, it should be like:

After fix, the script runs very fast.

Michael Saechang June 22, 2012 at 4:54 PM

Committed on:
Portal 6.2.x GIT ID: 3e6ceb7664615666aa2d6afd9c501b1d49ca6685.

Raymond Augé June 20, 2012 at 10:15 AM

Adding configurable thresholds:

Raymond Augé June 20, 2012 at 9:46 AM

I understand, but the same issue is true of simply storing these parameters in the PortletPreferences entity without putting it in the session because the PortletPreferences object is cached!

Perhaps there should be a threshold for the number of attributes stored in the preference, as well as for the size of the values themselves?

Fixed

Details

Assignee

Reporter

Branch Version/s

6.1.x
6.0.x

Backported to Branch

Committed

Fix Priority

3

Git Pull Request

Components

Priority

Zendesk Support

Created August 16, 2011 at 12:27 AM
Updated June 24, 2023 at 3:39 PM
Resolved August 6, 2012 at 10:29 PM
Loading...